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(54) TiUe: METHOD AND APPARATUS FOR ORGANIZING AND PROCESSING INFORMATION TJSINO A DIGITAL COMPUTER 
(57) Abstract 

An eflfca method and apparatus for cruizing and processrag chunks of interrelated information (or 'thoughts*') using a digital 
computer is disclosed. The invention utilizes highly flexible, associative thought nctwortcs to organize and represents digitally-stored 
thoughts. A thought network specifics a plurality of thoughts, as well as network relationship among the thoughts. A graphical representation 
of the thought network is displayed, inchiding a plurality of display icons corresponding to the thoughts, and a plurality of connecting lines 
corresponding to the relationships among the thoughts. Each of the thought is assocUted with one or more software application programs 
such as a word processing or spreadsheet utility. Users m able to select a current thought conveniently by interacting with the graphical 
representation, and the current thought is processed by automatically invoking the application program associated with the current thought in 
a transparent manner. Users can convenlenUy modify the thought network by intcracUvely redefining the connecting lines between Noughts. 
In another aspect of the invention, attribute vahjes arc associated with the various thou^ts of the network, and the network is searched to 
identify a subset of the thoughts having attribute values equal to a desired set of values. Further aspects of the invention include techniques 
for scheduling selected thoughts of the networit for desired operations at specified times, and storing timing and usage staUstics in order to 
preserve a history of the processuig tasks performed on each thought 
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METHOD AND APPARATUS FOR ORGANIZING AND 
PROCESSING INFORMATION USING A DIGFTAL COMPUTER 

Cross Reference of Related Applications 

This is a continuation-in-part of Application Serial No. 08/747,092, filed on November 
7, 1996 and claims the benefit of U.S. Provisional Application Serial No. 60/078,714, filed 
March 20, 1998. 
Field of the Invention: 

This invention relates to methods and apparatus for organizing and processing 
information, and more particularly, to computer-based graphical user interface-driven methods 
and apparatus for associative organization and processing of interrelated pieces of information, 
hereinafter referred to as 'thoughts.** 

BACKGROUND OF THE INVENTION 
The general-purpose digital computer is one of the most powcrfiil and remarkable 
information processing tools ever invented. Indeed, the advent of the digital computer, and the 
proliferation of a global digital information network known as the Internet, has thrust the world 
headlong into what is now recognized by many analysts as an "information era" and an 
"information economy,*' in which the ability to access and process information in an effective 
manner is one of the most important forms of economic power. 

The potential impact of the digital computer and the Internet on information distribution 
and processing is undeniably revolutionary. Yet, conventional software environments are 
generally organized around metaphors and principles from earlier eras. Text-based operating 
systems like Microsoft* DOS essentially treat the computer as a giant filing cabinet containing 
documents and applications. A strictly hierarchical file directory provides a rigid, trcc-iikc 
structure for this digital file cabinet. Individual documents are the "leaves" of this tree hierarchy. 
The directory structure generally does not include or express relationships between leaves, and 
users generally access documents and applications individually, using the directory structure. 
Even the now ubiquitous graphical "desktop" computing environment, popularized for personal 
computers by the Apple® and Microsoft Windows® operating systems, also simulates a 

1 
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traditional office environment. Individual documents and applications, represented by graphical 
icons, are displayed on the user's screen, to be accessed one-at-a-time. Once again, a strictly 
hierarchical, tree-like directory structure is imposed to organize the contents of the desktop. 

Although the desktop and file cabinet metaphors have been commercially successful, the 
limitations and drawbacks of these traditional metaphors become clear when one considers the 
strikingly different way in which the worid's other powerful information processing machine the 
human brain- organizes information. Instead of being confined and limited to strictly 
hierarchical file directory structures, the human brain is thought to intercomiect numerous pieces 
-of information through flexible, non-hierarchical, associative networics. As those of skiU and 
experience in the art are aware, it is often clumsy for users of traditional, prior art operating 
system interfaces to process multiple pieces of infomiation if these pieces are contextually 
related in some way. but are stored in separate files and/or are associated with different 
application programs. Too often, the prior art of organizing information lead users to 'misplace" 
information amongst hierarchical categories which often lose their relevance soon after the user 
15 creates them. Intended to assist users, traditional Werarchical structures and "desktop" metaphors 
compel users to organize their thought processes around their computer software, instead of the 
reverse. The inadequacy of "leal-world," hierarchical metaphors for information management 
was recognized prior to the advem of the computer, but untU now has not been successfully 
remedied. 

20 The recent deluge of digital information bombarding everyday computer users from the 

Internet only heightens the need for a unified, simple information management method which 
works in concert with namral thought processes. Additionally, users' ready enthusiasm for the 
World Wide Web graphical "hypertext" component of the Internet demonstrates the appeal of 
associative, nonlinear data structures, in contrast to the Umiting structure of computerized 

25 desktop metaphors. And yet, prior art web browsers and operating systems awkwardly compel 
users to navigate the associative, non-dimensional structure of the Worid Wide Web using 
linear, or at best hierarchical user interfeccs. They are also limited in their ability to provide 
differentiated content to different users of shared content 

What is desired is an effective methodology for organizing and processing pieces of 

30 interreUted information (or "thoughts'^ using a digital computer. The methodology should 
support flexible, associative networks (or "matrices'^ of digital thoughts, and not be limited to 
strict, tree hierarchies as are conventional, prior art technologies. A related goal is to create an 
intuitive and accessible scheme for graphically representing networks of thoughts, providing 

2 
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users with access to diverse types of information in a manner that maximizes access speed but 
minimizes navigational confusion. That methodology should be optimized to enable users to 
seamlessly manage, navigate, and share such matrices consisting of files and content stored both 
locally on digital information devices, as well as remotely via digital telecommunications 
5 networks such as local area networks, wide area networks, and public networks such as the 
Internet. A final goal is to facilitate relationships amongst users by flexibly distributing 
information about other users of shared content, and availing differentiated content to different 
groups of users. 

SUMMARY OF THE INVENTION 

10 The present invention enables users to organize information on a digital computer in a 

flexible, associative manner, akin to the way in which mformation is organized by the human 
mind. Accordingly, the present invention utilizes highly flexible, associative matrices to 
organize and represent digitally-stored thoughts. A matrix specifies a plurality of thoughts, as 
well as network relationships among the thoughts. Because the matrix structure is flexible, each 

1 5 thought may be connected to a plurality of related thoughts. A graphical representacion of a 
portion of the matrix is displayed, including a plurality of user-selectable indicia (such as an 
icon) corresponding to the thoughts, and in some embodiments, a plurality of connecting lines 
corresponding to the relationships among the thoughts. Each of the thoughts may be associated 
with at least one thought document, which itself is associated with a software application 

20 program. Users are able to select a current thought conveniently by interacting with the graphical 
representation, and the current thought is processed by automatically invoking the application 
program associated with the current thought document in a transparent manner. Upon the 
selection of a new current thought, the graphical representation of the displayed portion of the 
matrix (the "plex") is revised to reflect the new current thought, aU thoughts having 

25 predetermined relations to that current thought, and the relations therebetween. Users can modify 
the matrix by interiactively redrawing the connecting lines between thoughts, and relationships 
within the matrix are then redefined accordingly. Further a.spects of the invention include 
techniques permitting automated generation of thought matrices, delayed thought loading to 
facilitate navigation through a plex without undue delay due to bandwidth constraints, and 

30 matrix division and linking to allow optimal data structure flexibility. The present invention is 
also particularly well suited for use in conjunction with speech recognition in the manner 
disclosed. The present invention also is interoperable with digital commimications networks 
including the Internet, offers an intuitive methodology for the navigation and management of 

3 
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essentially immeasurable infomiation resources that transcends the limitations inherent in 
traditional hierarchical-based approaches, facilitates communications amongst users of shared 
network content, and permits the rapid publishing of content references by users and the 
exploitation of data based upon those communications and publishing activities. Finally, the 
present invention activates plcx displays and other levels of differentiated content in parallel 
with a user's navigation amongst primary shared network content 

IN THE THE DRAWINGS: 

Figure 1 illustrates the basic architecture of a computer system for use in implementing 
one embodiment of the present invention. 

Figure 2 illuistrates one embodiment of the data architecture for thoughts, in accordance 
with the present invention. 

Figure 3 illustrates a graphical user interface screen display, in accordance with an aspect 
of the present invention. 

Figure 4 illustrates the graphical user interface of Figure 3, reflecting the selection of a 
new current thought by a user. 

Figure 5 is a flow diagram showing the process for creating and relating thoughts in an 
"embodimentof the prcscnfinvention. ~ 

Figure 6 is a flow diagram showing the process for severing relationships between 
thoughts in an embodiment of the present invention. 

Figure 7 illustrates a graphical user interface screen display, in accordance with another 
aspect of the present invention. 

Figuire 8 illustrates a graphical user interface screen display, in accordance with another 
aspect of the present invention. 

Figure 9 illiistrates a graphical user interface screen display, in accordance with another 
aspect of the present invention. 

Figure 10 discloses an algorithm which may be implemented in an embodiment of the 
present invention. 

Figure 1 1 Ulustrates a graphical user interface screen display, in accordance with another 
aspect of the present invention. 

Figure 12 illustrates a graphical user interface screen display, in accordance with another 
aspect of the present invention. 

Figure 13 illustrates a graphical user interface screen display, in accordance with another 
aspect of the present invention. 

4 
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Figure 14 illustrates one embodiment of a dialog window for editing thought fields. 
Figure 15 illustrates one embodiment of a calendar window in conjunction with a 

hypothetical plex. 

Figure 16 illustrates the data architecture of one embodiment of the ".bm" (modified 

hcadcase) file of the present invention. 

Figure 17 sets forth algorithms for implementing forgetting and remembering operations 
that are used with one embodiment of the present invention. 

Figure 18 depicts five intenelated screen displays of one embodiment of the present 

invention. 

Figure 19 illustrates a hypothetical screen display of an information storage arrangement 

having non-differentiated links. 

Figure 20 illustrates the screen display that would result upon the selection of an element 

from the hypothetical screen display of Figure 19. 

Figure 21 illustrates an alternative graphical user interface screen display, in accordance 
1 5 with one embodiment of the present invention. 

Figure 22 illustrates a flow chart describing one method for implementing the delayed 
loading feature of one embodiment of the present invention. 

Figure 23 iUustrates a method for drawing a plex having distant thoughts. 

Figure 24 illustrates an alternative algorithm for searching thoughts that may be 
20 implemented in an embodiment of the present invention. 

Figure 25 illustrates a graphic user interface screen display containing distant thoughts. 

Figure 26 iUustrates a network structure for facilitating communications amongst content 



users. 



Figure 27 illustrates a network structure for facilitating users' publishing of sets of sets of 

25 references to shared data to o&er users. 

Figure 28 iUustrates a client-server dialog enabling multipoint sharing of users' positions 

within a matrix. 

Figure 29 illustrates examples of screen displays showing positions of other users of a 

plex. 

30 Figure 30 Ulustrates a flow chart showing a method for implementing an instant matrix 

publishing embodiment of the present invention. 

Figure 3 1 Ulustrates a netwoik structure for paiaUel content distribution. 
Figure 32 Ulustrates a flow chart describing one method of implementing a paraUel 

5 
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content browser. 

Figure 33 illustrates a flow chart describing one method for implementing a parallel 
content server. 

Figure 34 illustrates a flow chart describing one method for generating a matrix 
5 corresponding to a map of a web site or other self-referencing, linked files. 

Figure 35 illustrates a graphical user interface for the algorithm illustrated in Figure 

34. 

Figure 36 illustrates a screen display for the automated generation of thought matrices 
from preexisting independent groups of infonnation. 
10 Figure 37 illustrates a flow chart describing one method for creating virtual thoughts. 

Figure 38 illustrates a flow chart describing one method for deleting virtual thoughts. 

NOTATION AND NOMENCLATURE 

The detailed descriptions which follow are presented largely in terms of display images, 
algorithms, and symbolic representations of operations of data bits within a computer memory. 
15 These algorithmic descriptions and representations are the means used by those skilled in the 
data processing arts to most eflFectivcly convey the substance of their work to others skilled in 
the art. 

An algorithm is here, and generally, conceived to be a self consistent sequence of steps 
leading to a desired result. These steps are those requiring physical manipulations of physical 

20 quantities. Usually, though not necessarily, these quantities take the form of electrical or 
magnetic signals capable of being stored, transferred, combined, compared, and otherwise 
manipulated. It proves convenient at times, principally for reasons of common usage, to refer to 
these signals as bits, values, elements, symbols, characters, images, terms, numbers, or the like. 
Et should be bomc in nund, however, that all of these and similar terms are to be associated with 

25 the appropriate physical quantities and are merely convenient labels applied to these quantities. 

In the present case, the operations are machine operations performed in conjunction with 
a human operator. Useful machines for performing the operations of the present -invention 
include general purpose digital computers or other similar devices. In all cases, there should be 
borne in mind the distinction between the method operations of operating a computer and the 

30 method of computation itself. The present invention relates to method steps for operating a 
computer and processing electrical or other physical signals to generate other desired physical 
signals. 

The present invention also relates to apparatus for performing these operations. This 

6 
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apparatus may be specially constructed for the required purposes, or it may comprise a general 

purpose computer selectively activated or reconfigured by a computer program stored in the 

computer. The algorithms, methods and apparatus presented herein arc not inherently relaxed to 

any particular computer. In particular, various general purpose machines may be used with 

5 programs in accordance with the teachings herein, or it may prove more convenient to construct 

more specialized apparatus to perform the required method steps. The required structure for a 

variety of these machines will appear bom the description given below. 

One aspect of the present invention relates to the organization, storage, and retrieval of 

information with highly-flexible associative data stnictures, and it is^^A^ ~ 

1 0 explain the disclosed processes by analogy to processes commonly associated with human 
cognition. For example, as explained above, items of information that are processed in 
accordance with the present invention are referred to by the label 'thoughts,' and designations 
such as "forgetting* are used metaphoricaUy to refer to functions or relations relating to the 
associative data structure of the present invention. These analogies are employed merely to 

15 facilitate explanation of the present disclosure. Based on everyday assumptions regarding the 
way humans think, the distinctions between the presentiy disclosed computer-implemented 
- invention and actual-h\mian cognitive operations must not be overlooked. The interrelations 
among these thoughts are sometimes similarly defined by reference to genealogically-derived 
terms such as "parent' and "child' thoughts. In the spirit of the present invention, the assignment 

20 of these terms is based largely on human intuition, as they reflect relations between thoughts that 
may easily be grasped by users not proficient with the use of nontraditional information storage 
schemes. The terms are merely labels that serve to enhance the clarity of the disclosure. They 
should not be construed as restricting the flexibility of the described information storage 
structure. 

25 DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

General System Architecture 
Figure 1 depicts the general architecture of a digital computer system 90 for practicing 
the present invention. Processor 100 is a standard digital computer microprocessor, such as a 
CPU of the Intel x86 series. Processor 100 runs system software 120 (such as Microsoft 
30 Windows-, Mac OS- or another graphical operating system for personal computers), which is 
stored on storage urut 1 10, ~ a standard internal flxed disk drive. Software 130, also stored on 
storage unit 1 10, includes computer program code for performing the tasks and steps described 
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below, including the digital representation of matrices, the display of graphical representations 
of such matrices, and the processing of such matrices in accordance with the principles of the 
present invention. Display output, including the visual graphical user interface CGUTO 
discussed below, is transmitted from processor 100 to an output device such as a video monitor 
5 1 40 for display to users. Users utilize input devices such as standard personal computer 

keyboard 150, cursor control device 160 (e.g., a mouse or trackball), touch-screen sensors on the 
monitor display, virtual reality gloves, voice input, or similar techniques to enter the GUI input 
commands discussed below, which are then transmitted to processor 100. Software for 
implementing the present mvention may be stored in a variety of locations and in a variety of 

1 0 mediums, including vwthout limitation, RAM, data storage 1 1 1 , a network server, a fixed or 
portable hard disk drive, an optical disk, or a Hoppy disk. 

Internal Implementation of a Thought 
In one embodiment of the present invention as illustrated in Figure 2, a plurality of 
interrelated thoughts collectively make up a ''thought.* Each such thought (i.e., a piece of 

1 5 information, such as a collection of spreadsheet data) is represented internally as comprising 
various elements, including properties and relationships. Properties can include, as in the 
example of thought 200: number 205, name 210, key words 215, docimient 220, usage statistics 
225, priority 230, flags 235. category 240. Relationships can include currently linked thoughts 
245 and past linked thoughts 250. Except for document 220, all of the data for all thoughts is 

20 stored in a set of files 255 (which we designate 'the headcase" in one embodiment), which is 
invisible to the user and is transparently loaded to RAM and saved to data storage ill as the user 
works. 

Number 205 . Each thought has a unique number which, in some embodiments of the 
present invention, is invisible to the user but is used internally, by other thoughts or lists, to 
25 reference the thought. References to each thought thus occupy only a small amount of internal 
storage, and changes to a thought's user-specified name do not affect internal references. 

Name 210 . The "name" of a thought is intended to be a brief, textual description of that 
thought, written by the user. One purpose of a name is to enable users to identify the associated 
thought in a convenient manner. 
30 Kev Words 215 . The "key words" of a thought are a list of descriptive terms inputted by 

the user, which list may be interactively searched using the search methods described in more 

detail below (sec "Searching")- 

Document 220 . Each thought includes an associated "document," which stores all of the 

8 
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specific content for that thought, such as word processing data or spreadsheet data. Each such 
document is stored internally in its own file in data storage 1 1 1 or separately stored in noass 
storage devices accessible by the computer system. 

In some embodiments of the invention, the document name is based on the associated 
5 thought's number. En other embodiments, the document name may be based on the name of the 
associated thought More particularly, the document name can be the same as the thought name, 
unless a preexisting file with the identical name akcady exists. If such a file already exists, the 
method of the present invention can name the location by appending a number to the name. For 
some embodiments of the present invention used with operating systems that use filename 
1 0 extensions, the extension for the location may be determined by the thought type in accordance 
with common practices in the art, for example, ".tht" for thought editor documents, and ".htm*" 
for web pages. 

When the name of a thought is changed, the location of the document it references is not 
changed. This allows the user to use the location to share the file with users who are not using 

1 5 the method of the present invention and therefore must access these files through traditional 
operating system methods. Of course, a user may edit the location of a document by the same 
methods used to edit all other thought properties. If the user makes the location point to a 
nonexistent or unsupported file, the software of the present invention will be unable to edit the 
document The referenced file may be either locally or remotely located. 

20 Referenced files may also be used as sources for Microsoft Windows® drag and drop 

operations known in the artand extensively documented in Windows® Software Development 
Kits. These operations are capable of exchanging file locations between programs for the 
purpose of making references, embedding, copying, and pasting. By implementing these 
operations into the software of the present invention, a user can use the present invention as a 

25 Jrop source. A file stored using the present invention may thereby easily be copied to a ^mdows 
Explorer® folder or any other application supporting file drag and drop. 

As discussed below, the user need not consciously manage these files. Instead, accessing 
a thought automatically provides the user with a seamless, transparent way of accessing the 
document contents, calendar information, notes and other information associated with thought, 

30 along with the appropriate application program(s) or utility(ics) for processing those contents. 

Usape Statistics 225 . "Usage statistics" may be generated and stored for each thought as 
the user works on that thought, as discussed in greater detail below in the "Additional Features" 
sectioiL 

9 
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Priority 230 . A priority number set by the user indicates the relative importance of a 

particular thought The priority is normally manually set by the user, but can be calculated based 

upon the usage statistics and the relationships at the user's request The priority can then be used 

to filter thoughts when searching or creating thought lists. 

5 Flags 235 . Flags provide a mechanism for designating the state of each thought In one 

embodiment of the invention, each flag can be in one of three states: on. off, or default. When a 

flag is in default, the thought value is determined by the category of thought (sec Category, 

below). Flags can be user-defined, or may be automatically provided by the system. One 

example of a system flag is one that states whether a thought is part of long term memory. 

1 0 Category 240 . A thought's "category" is a number which designates a thought to be of a 

specific category. Thought categories are defined and named by the user. Each category specifies 
that thoughts of that category will have certain attributes or "fields," as well as certain default 
flag values (see the discussion of "flags" above). An example of a category might be "Person," 
in which case an example field might be "City of Residence.'' The use of fields to perform 

1 5 indexed searching is discussed in further detail below, in the "Processing Thoughts" section. 
Category definitions may be stored separately, as templates. 

Relationships Between Thoughts 245 . In one embodiment of the invention, at least three 
types of relationships are possible among thoughts: child, parent, and jump. Each thought 
includes a separate list for each type of relationship. The utility of enabling at least three types of 

20 links among thoughts is discussed more fully below. Each such relationship list stores a list of 
the other thoughts (identified by number) that are related to the instant thought by the instant 
type of relationship. The relationship lists are used to generate and navigate graphical 
representations of the matrix, as described in detail below, and are otherwise iirvisible to the 
user. 

25 Past Relationships 50 . In some embodiments of the invention, there is another set of at 

least three lists: for child, parent, and jump relationships, respectively, which archive 
information about those relationships vAnch have been severed or "forgotten" but which may be 
reattached or remembered upon request by the user. Essentially, this provides a long term 
memory facility that allows users to recall previous relationships when desired, without 
30 cluttering the current display with non-current data, as discussed below. 

Graphically Representing and Navigatin;^ a Matrix 
The present invention simultaneously enhances navigational efficiency through its 
strategic graphical arrangement of display icons representing thoughts. The placement of the 

10 
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thoughts reflects second-level relations that may not be as easily communicated by techniques 
employing arbitrary thought placement Figure 3 illustrates a typical, graphical representation 
("plex 300*0 of a matrix of related thoughts which will be displayed on the monitor 140, in 
accordance with one embodiment of the present invention. Figure 21 illustrates an example of an 
5 on-screen display of an alternative embodiment of the present invention, in which the plex is 
displayed in the upper-right-hand section of the screen, the thought document is On the left-hand 
portion of the screen, and properties, list manager, and notes windows are on the lower right 

section of the screen. 

Thought Types and Interrelation . In the example of Figure 3, central thought 310 

1 0 labelled **NatrificiaI" is displayed in the center of the plex, preferably surrounded by a circle, a 
dashed rectangle, and a rotating or blinking graphic that visually draws attention to the cenual 
thought. Thoughts that are directly related to the central thought 3 10 are represented in the plex 
300 by display icons connected by lines to the central thought In one embodiment of the present 
invention, multiple categories or types of thought relationships can be specified, in the interests 

1 5 of providing users maximum organizational flexibility and clarity. Specifically, the present 

invention allov^^ a plurality of parent thoughts, a plurality of child thoughts, a plurality of sibUng 
thoughts, and a plurality of jump thoughts. 

Sibling thoughts (such as the thought "ParaGen' 322), are child thoughts of any and all 
parent thoughts (such as the thought "Software" 3 12) of the current central thought ('Natrificial" 

20 3 1 0). For example, in the embodiment illustrated in Figure 3, above the central thought 3 1 0 are 
related parent thoughts. In this plex there is only one, "Software" 312. Below the central thought 
are child thoughts. In this plex there are three: "Projects" 3 14, "Resources" 316, and 
"Information" 318. To the left of the central thought are jump thoughts: in this plex there is only 
one: Nomenclature' 320. Finally, to the right of the central thought are sibling thoughts which 

25 share a parent with the central thought. In this plex there is only one, "ParaGen" 322. The 
underiying significance and semantics of these or other categories of thought relationships is 
entirely unique to the individual practitioner and user. In one embodiment, parent thoughts are 
displayed in three columns extending upward torn the central thought, jump thoughts arc 
displayed in a single column extending upward from the central thought and to the left of the 

30 parents, and children are displayed in four colunms beneath the central thought and extending 
downward. 

The display of sibling thoughts is not required for navigation through a plex. For this 
reason, some embodiments of the present invention allow the user to elect in the preferences not 
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to display siblings. Such an election may conserve display space, but will do so at the cost of 
displaying fewer available thoughts. One embodiment of the invention is configurable in the 
display preference settings to display other more distantly related thoughts (collectively "distant 
thoughts'*), including grandparents, grandchildren, and partner thoughts. Grandparent thoughts 
are the parents of the parents, and may be displayed above the parents in two coiumns extending 
upward. Grandchildren are the children of the children, and are displayed below the children in 
four columns extending downward. Partners are the parents of the children, and may be 
displayed to the left of the active thought and below the jumps. If there are many partners or 
many jumps, the jumps may be shifted to accommodate the partners. Graphical representations 
of distant thoughts may be smaller than those for thoughts more directly related to the central 
thought, and may not contain gates from which relationships may be originated; these distant 
thoughts can be highlighted as the selection cursor passes over them. One method for graphically 
representing a plex having distant thoughts is outlined in Figure 23. As this figure illustrates, this 
process includes generating a list of thoughts to be drawn and their respective screen locations, 
drawing connecting lines between these thoughts, and then drawing the thoughts themselves. 
Figure 25 is an illustrative screen display having distant thoughts 2500A-N, as described above. 

Parent, child and jump thoughts are all equally related insofar as each is directly linked 
to that centra] thought. The jump thought is unique in that no thought related to a jump thought 
is displayed within the plex, unless that thought is itself a parent, child, or sibling of the central 
thought. Sibling thoughts are secondary relations, connected to the central thought only 
indirectly through parent thoughts and children thoughts. The distinctions amongst the types of 
thought relationships can be symbolized within a single plex by displaying lines connecting the 
thoughts. Those distinctions achieve added significance in the plexes resxdting from a user 
navigating the matrix, activating a different thought as the new central thought Preserving the 
distinctions amongst types of thought relationships permits a data management structure which 
at once lends itself to easy, logical navigation-like hierarchial structures and yet enjoys the 
dimensionless and unlimited flexibility of a totally associative structure. 

The differing relations among thoughts are reflected in the following general rules, 
which define the coUection of thoughts graphically represented in a plex as well as the nature of 
this representation in some embodiments of the present invention. 

Depending upon the defined interrelations between the old central thought and the 
newly selected central thought, the other thoughts in the old plex may be included or excluded 
from the new plex. The Id central thought, however, will always remain in the new plex. Parent 
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thoughts are related to all of their child thoughts, and child thoughts are related to one another. 
Therefore, when a child thought is selected, all the other children will remain in the plex as 
siblings. Likewise, when a parent is selected, the other children of the parent (i.e., some or all of 
the siblings of the current central thought) will remain in the plex. Furthermore, sibling thoughts 
5 are related to each other and their parents, so that when a sibling is selected, all of its siblings 
(some or aU of the siblings of the original central thought) will remain in the plex as siblings. 

Jump thought relationships link the jump thought with only the central thought and no 
other thoughts- therefore, when a jump thought is selected, typically only it and the current 
central thought will remain in the plex. Non^ontcxtual links such as those inserted Into 
10 hypertext are effectively the same as jump links, as they do not help to define relationships 
beyond those that are directly linked. The availability of such non-contextual links within, for 
example, hypertext documents, expands the breadth and enhances the flexibiUty of the presenUy 
disclosed invention and dicrefore increases its capacity to provide an optimally intuitive and 
adjustable structure for organizing information. 
1 5 r^phical Reor r r"^**'"" of Matrix . In one embodiment of the invention, each tiiought in a plex 
has three circles near it. These circles are thought "gates" (e.g.. gates 330, 340, and 350 in Fig. 
3), and are used to show and create the relationships between thoughts. The location of each 
gate tells what kind of relationship it represents. Thus, gate 330 above thought 3 1 0 is for 
relationships to parent thoughts; gate 350 below tiiought 3 10 is for relationships to child 
20 tiioughts; and gate 340 on tiie side of tiiought 310 is for relationships to jump tiioughts. Note tiiat 
each thought intiie display of Figure 3 is connected to central thought 310 by tiie appropriate 
gate. Each gate circle being used (i.e.. a gate tiirough which a tiiought is connected) may be 
fdled (e.g., gate 330); if no tiiought is connected tiirough a gate, tiiat gate's circle is empty (e.g.. 
gate 340). In addition, gates may be color^oded according to tiie currentiy displayed tiioughts. 
25 For example, in one embodiment, if a gate is red (e.g., gate 350), tins indicates tiiat all tiie 
tiioughts to which it connects are currentiy displayed. If a gate is green (e.g., gate 365), tiiis 
indicates tiiat tiiere are otiier tiioughts to which it is connected and which are not displayed 
within the plex at this nine. 

Display of tiie plex may be configured based upon tiie current tiiought More 
30 specifically, tiie display positions of tiioughts are determined by tiie way tiiey are related and tiie 
number of tiioughts tiiat are related in tiiat way. Thus, in one embodiment, tiie central tiiought 
(e.g.. 3 1 0) is always drawn in tiie center. Above tiie central tiiought are tiie parent tiioughts e.g., 
312), which are drawn in up to two columns extending upward. Below tiie central thought are 
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the chad thoughts (e.g., 314, 316, 318), which are drawn in to four columns extending 
downwaid. The jump thoughts appear to the left in a single column which extends up and down 
until it hits the child thoughts, at which point it begins to extend only upward. Sibling thoughts 
appear to the right of the central thought in a single column which extends up and down until it 
5 hits the child thoughts, at which point it begins to extend only upward. In practice, the actual 
drawing sequence on screen may be performed as follows. First the background is cleared. The 
scaUng circle and the lines that connect the thoughts are then drawn. Next, the lines are drawn 
between the locations of the gates representing the appropriate relationships. FinaUy, the actual 
thought names and the gates are drawn. 

1 0 Occasionally a centriaJ thought will be linked to so many thoughts that it will be 

impossible to simultaneously display all thoughts in a plex. In one embodiment of the present 
invention, the software of the present invention will display arrov^fs above andlor below thoughts 
widi particular relations to thoughts that could not be accommodated on the display. By clicking 
on or dragging these anov^fs, the user may scroll through the entire list of thoughts. When 

1 5 second-level thoughts are displayed, only those which are linked to the thoughts displayed will 
be displayed. 

Matrix T^gation .NaviRation andmbvCTnent througlTthematiixis accomplished by selecting 
the thought to be moved to, using control device 160 or keyboard 150. In one embodiment, 
navigation is accomplished by selecting a thought indicium with a cursor control device such as 

20 a mouse. When a thought in the plex is selected to become the new central thought, the plex is 
rearranged according to the links associated with the newly selected central thought. In some 
embodiments, this process may be graphically reflected with animation showing the movement 
of the thoughts. For example. Figure 4 shows the plex of Figure 3 but rearranged after a user has 
interactively selected Software 3 12 as the new central thought, in place of Natrificial 310. 

25 ^^Tmdow 360 is used to display and edit the document for the current thought as discussed below 
in the section entitled "Processing Thoughts." 

One method of navigation using a keyboard utilizes the arrow keys in connection with 
other keys. In one particular embodiment, thoughts may be activated using a combination of the 
[Alt] key and the arrow keys. Upon the depression of the [Alt] key, a cursor is initially displayed 

30 over the central thought Subsequent depression of the [Up] key may move the cursor to the 

closest parent, [Down] to the closest child, and so on. Within a group of thoughts, the arrow keys 
can be used to move the cursor aniong the group. The [Left] key may be assigned to return to the 
central thought from the siblings, and the [Right] may be assigned to return to the central 
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thought from the jumps. The [Down] key will only return to the central thought from the parents 
if the cursor is over the bottom parent thought The [Up] key will only return to the central 
thought from the children if the ctirsor is over the top child thought. If the display includes 
scrollbars, the [Up] and pown] keys may be used to scroll. A selected thought may then be 

. 5 activated by the release of the [Alt] key, or in another embodiment, the [Alt] key may be pressed 
once to begin a thought selection routine and a second time to activate a selected thought 

Navigation Example . Figure 18 illustrates five related screen displays of one 
embodiment of the present invention. These connected displays demonstrate the practical 
significance of the novel interrelations among the different types of thought relationships of the 

1 0 present invention. Specifically, using differentiated types of thought relationships enhances the 
relevancy of the plex, by displaying only the most interrelated thoughts. The center screen 1800 
illustrates a hypothetical plex, and each of the four screens bordering this hypothetical plex 
1810, 1820, 1830, and 1840 illustrates the plex that would be displayed upon the user's selection 
of a particular one of the thoughts from the original hypothetical plex to be the central thought 

1 5 As Figure 1 8 shows, the original plex 1 800 comprises a central thought C*Central") in the center 
of the plex, surroimdcd by and connected to a muhiplicity of jump, parent, sibling, and child 
thoughts. For simplicity, this example presumes that, contrary to thoughts in a typical plex, none 
of the thoughts in the original plex are connected to any thought outside the original plex, and 
that each thought is connected to that central thought by only one type of thought relationship. 

20 Also for simplicity's sake. Figure 1 8 assumes that sibling thoughts are the only indirect thought 
relationships displayed, and that the illustrated embodiment will not display distant thoughts. 

The screen 1810 above the original plex illustrates the plex. that would result if the user 
selected the Tarent 1" thought from the original plex. As Figiur 18 illustrates, the Parent I 
thought in the original plex was cormected only to the central thought and to the thoughts labeled 

25 Sibling I and Sibling 2. Upon the selection of Parent I" fi^m the original plex, the Parent 1 
thought moves to the center of the plex display, and the thoughts linked thereto move 
accordingly into position around the Parent 1 thought The names assigned to the thoughts in 
each of the five screens are based on the position of the thoughts in the original (center) plex, 
and were not changed so that one could follow the movement of each thought from the original 

30 plex to each of the peripheral plcxes. Therefore, Sibling I and Sibling 2, vAich were siblings of 
the original central thought and therefore were displayed on the right-hand side of the plex. 
move into position xmdcr Parent I in the top plex because Sibling I and Sibling 2 are children of 
Parent 1 (the new central thought). As explained above, children thoughts are displayed at the 
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bottom of the plex. The original central thought, labeled "Central," is also a chOd of Parent 1 and 
therefore is also displayed below Parent 1. Jump I and Jump 2 were related only to the central 
thought within the original plex. arc not directly related to Parent 1 , and are therefore not 
displayed within the new plex. Child I, Child 2 and Child 3 are now grandchildren and are not 
5 displayed. Neither is Parent 2 which is now a partner, nor Siblings 3 and 4 which arc related to 
Parent I only through three thought relationship links ('links*). 

The plex 1 840 to the right of the original plex 1 800 is the plex that would result upon 
the selection of Sibling I as the new central thought. Specifically, as shown in the original 
(center) plex. Sibling I is directly connected only to Parent 1 . Therefore, the new plex shows 

10 Sibling 1 as the new central thought, with Parent 1 (Sibling I's parent) connected above. 

Furthermore, because Sibling 1, Sibling 2 and Central share Parent 1 as a common parent, they 
are siblings of one another. Sibling 2 and Central are displayed as sibling thoughts to the right of 
Sibling 1 in the new plex. Again, Jump 1 and Jump 2 were related only to the central thought 
within the original plex, are not directly related to Sibling 1, and are therefore not displayed 

15 within the new plex. Child 1, Child 2 and Child 3, Parent 2, Sibling 3, and Sibling 4 are not 
displayed because each is at least three links removed. 

The plex 1830 below the original plex 1 800 is the plex that would result upon the 
selection of Child 1 as the new central thought. Specifically, as shown in tiie original (center) 
plex. Child 1 is directly connected only to the original central thought. Therefore, the new plex 

20 includes Child 1 as the new central thought and includes the original central thought as a parent 
thought displayed above Child 1 (because Child 1 is a child of Central, Central is a parent of 
Child 1). Furthermore, as the original plex shows. Child I. Child 2. and Child 3 share Central as 
a common parent and therefore are all siblings. Thus. Child 2 and Child 3 are displayed as 
siblings of Child 1 on the right-hand side of the plex. Again, Jump 1 and Jump 2 were related 

25 only to the central thought within the original plex, are not related to Child 1 , and are therefore 
not displayed within the new plex. Parents 1 and 2 would now be grandparents and are not 
displayed. Neither are Siblings 1, 2, 3 and 4 which are at least three links removed from Child 1 . 

The plex 1820 to the left of the original plex 1800 is the plex that would result upon the 
selection of Jump 1 as the new central thought. Specifically, as shown in the original (center) 

30 plex. Jump I is directly connected only to the original central thought, and is not directly related 
to any other thoughts in the original plex. Therefore, the resulting plex includes only Jump 1 as 
the new centra] thought and Central as a jump thought. 

Advantaees of Associative Interrelations . As this example graphically illustrates, the 
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relatedness of particular thoughts is reflected in the manner in which those thoughts arc 
displayed as the user navigates the matrix. By choosing one type of link ova: another, the user 
has the power to affect the content of the plexes that are displayed i^on the selection of any 
thought from the current plex as the new central thought. The method of the present invention 
5 utilizes intuitively-derived thought interrelations and graphical representations to optimize the 
benefits human users will obtain from the present invention. Harnessing this pov^er offers the 
user informational displays that are as or more relevant than hierarchical displays, yet free of the 
artificial spatial limitations inherent in hierarchies and "real world" metaphors. 

These advantages become particularly clear when the interface and stomge structure of 

1 0 the present invention are contrasted against a system having nondiffercntiated links. A 

hypothetical screen display of such a system is shown in Figure 19. This display is one possible 
representation of a central thought related to eight otiier tiioughts. However, no information 
about the nature of this interrelation may be gleaned by the graphical representation of Figure 
19. The inherent limitations of systems capable of only a single type of association are strikingly 

1 5 apparent when one considers tiie plex that would result upon the selection of one of tiie thoughts 
depicted in Figure 19. As Figure 20 illustrates, the plex resulting from the selection of a thought 
from tiie hypothetical plex of Figure 19 would contain only two individual tiioughts. connected 
by a single non-differentiated link. The present invention overcomes these deficiencies and 
allows an optimally flexible, intuitive, and tiierefore efficient means for organiang information. 

20 Defining a Matrix 

(^reating New Thoughts . New thoughts may be created by interactively clicking and 
dragging, using mouse/control device 160. from any of die gates around an existing tiiought 
Figure 5 provides a flow diagram showing tiie basic steps of tiiis process. At step 500, the user 
selects by choking on a gate of an existing tiiought (a "source tiiought"), to which tiie new 

25 tiiought is to be related. At step 5 1 0, tiie user drags control device 1 60 away from tiie source 
tiiought; during this step, a "rubber-band' line may be displayed coming out of the source 
tiiought gale and tracking tiic cursor controlled by mouse/control device 160. At step 520, the 
mouse/control device's 160 button is released. At tiiat point, if tiie cursor controUed by 
mouse/control device 160 is located over an existing tiiought (a "target tiiought"), as indicated at 

30 decision point 530, then tiie system assumes the user desires to create a new relationship 

between tiie source thought and the target tiiought, as will be described shortiy below. In order to 
create a new tiiought, the user simply releases mouse/control device 160 witii the cursor at an 
unoccupied location on tiie screen. In that case, as shown at step 540, a new tiiought is created 
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and added to headcase 290. In one embodiment, a dialog box 710 (see Fig. 7) appears and asks 
for the new thought's name and/or other properties; a unique new thought number is created to 
refer to this thought; all f the new thought's data fields are initialized to default values; and the 
thought's number is added to a global list of aU thoughts. At this time a user may specify a 

,5 plurality of thoughts to be linked in the same manner. The present invention can automatically 
link preexisting thoughts specified at this time. 

Next, at step 550. a relationship is created between the source thought and the new 
thought, based in some embodiments upon the type of gate of the source thought that was 
selected at step 500. In particular, the new thought's number is added to the appropriate 

1 0 relationship list (245) of the source thought, and the source thought's number is added to the 
appropriate relationship list (245) of the new thought. Finally, at step 560, the updated plex is 
redrawn, reflecting the newly created thought and its relationship to the source thought 

Relating Existing Thoughts . Existing thoughts may be related using the same method as 
is used to create new thoughts. Referring again to Fig. 5. steps 500 through 520 are the same. 

15 However, at decision point 530, control device 160 is determined to have been released with the 
cursor located over an existing thought (the 'target thoughf^- In that case, at step 535, the 
relationship list 245 (Fig. 2) of the source thought and target thought are checked to ensure that 
the thoughts are not already directly related. If such a relationship does exist, it may be deleted at 
step 545 by removing the source and target tiioughts' numbers from each otiier's current 

20 relationship Usts, to avoid any ambiguities. Next, at step 550, the source and target tiioughts' 

numbers are added to each otiier's appropriate relationship list 245), as determined by tiie source 
tiiought's gate type originally selected at step 500. The redefined matrix is redrawn at step 560. 
If such a relationship does not exist, tiien step 545 is inapplicable and step 550 is processed 
immediately after step 535 is executed. 

25 ]pf. ^rHering Relations . Related tiioughts are drawn in tiie plex according to tiic order tiiey 

are Usted in tiie relationships Ust of tiie central tiiought. By dragging tiie tiioughts in tiie display, 
tiie user can specify in what order they should be listed and as a result, where tiiey will appear. 
In reference to Figure 3, Figure 8 provides an example of tiie display 800, in one embodiment, 
which would result if a user were to interactively reverse tiie order of tiioughts 316 and 3 18. 

30 causing tiie icons representing tiiose tiioughts 3 1 6 and 3 1 8 to switch horizontal positions as 

demonstrated by tiie positions of tiiose tiioughts 316 and 318 in Figure 8 or if a digital computer 
were to reorder tiiose tiioughts based upon an alphanumeric sequence, usage statistics, or otiier 
logical criteria. 
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Severing Relations Between Existinp Thoughts . It is possible to sever the relationship 
between two existing thoughts, such as central thought 310 (**Nalrificial") and child thought 314 
("Projects")> using a process similar to the process used to define a new relationship between 
existing thoughts. As the flow diagram in Figure 6 outlines, at step 600, the user requests that a 
5 particular relationship be severed by clicking on the lines which connect two thoughts such as 
the line connecting thoughts 310 and 314 in Figure 3, Next, at decision point 610, a check is 
made to sec if the requested severing would mvolve the special case of "forgetting," as will be 
explained shortly. If no "forgetting" will occur, then at step 660 the numbers of the two thoughts 
- are removed fit)m each other*s relationship lists and the line between thoughts-310 and 3 14 in 

1 0 the graphical display shown in Figure 3 may be removed. 

The special case of "forgetting" an existing relationship will now be explained. Consider 
the example plex shown in Figure 3. If the relation between thought 314 ("Projects") and central 
thought 310 C^Natrificial") is severed, then there will be no path at all connecting thought 314 
with central thought 310, and thus no way to access thought 314 bom the current thought 

1 5 Thought 3 1 4 will be isolated. In that sense, thought 3 1 4 will be "forgotten' if the severing is 
performed. Therefore, in the process depicted by Figure 6, decision point 610 detects such cases 
(see below, "Determining if thoughts will be isolated"); In'such cases, the number of the 
"forgotten" thought (i.e., thought 314) is deleted from the current relationship list 245 (Figure 2) 
of central thought 310 at step 620, and is added to the corresponding past relationship list 250 of 

20 central thought 3 1 0. Recall that the past relation lists 250 are included as part of each thought's 
data structure, as illustrated in Figure 2. Next, the forgotten thought's own fields are revised to 
reflect its status as a 'forgotten" thought: namely, at step 630, thought 3 14's current relationship 
lists 245 arc merged into its past relations lists 250 (i.e., copied from 245 to 250 and then erased 
from 245), and at step 640 its "long term memory" flag is set to "on." At step 650, forgotten 

25 thought 314 may be added to a global long term memory thought list. At step 670, the plex is 
redrawn, reflecting the absence of forgotten thought 314. It is possible to forget more than one 
thought at once, in w*ich case all of the forgotten thoughts will be modified as described for 
thought 314. 

By reference to particular tisage statistics, the forgetting operation may be automated. 
30 More precisely, the present invention may automatically forget a thought that has not been 
accessed within some user-definable period of time, as reflected by the usage statistics 
associated with ^t thought. 

Determining If Thoughts Will Be Isolated . A th ught will be isolated when it is not 
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possible to return to the ceotral thought via any link other than that link wiiich is being severed. 
Similarly, any thoughts C'Rodin" 950 and "Liquid Noise" 960 in Figure 9) related to the severed 
thought CTrojects" 314) will be forgotten so long as their only link to the central thought existed 
via the severed thought ("Projects" 314). One method of determining whether it is possible to 
5 return to the central thought from a thought whose link has been severed is illustrated by the 
recursive algorithm disclosed in Figure 10. 

An alternative method that may provide enhanced performance is disclosed in Figure 
24. This method relies on a programming object termed a ThoughtList which utilizes a map of 
bits representing thought numbers. Each bit in the map corresponds to a thought, with a (1) 
1 0 indicating a thought on the list and a (0) indicating a thought not on the list In accordance with 
this methodology, one can store the existence or nonexistence of over a million thoughts using 
merely 128 kilobytes of storage. The storage required for this technique is determined by the 
highest possible thought number divided by eight. All memory or storage used for this list is 
zeroed out, and is subsequently modified (to I 's) at locations corresponding to thoughts. 
1 5 Specifically, when a thought is added to the list, the bit number X of byte number Y is set, where 
X is the remainder of the thought number divided by eight, and Y is the thought number divided 
by eight This method may also be used for "storing normal thought lists^^ 

Parentless Thoughts . An alternative embodiment of the present invention maintains a list 
of parentless thoughts (thoughts without parents) that is updated whenever changes are made. 
20 When a thought is created, linked, or unlinked, the affected thoughts are checked for parents. If 
these thoughts have parents, they are removed from the list; otherwise, they are added to the list. 
If necessary, the list of parentless thoughts may easily be regenerated by checking all thoughts 
for parents. Because this list is maintained, it is not necessary to ensure that all tho\ights are 
connected. Thoughts may therefore be unlinked without verifying the existence of alternative 
25 return routes to the original thought 

Forgetting, and Remembering Without Searching . When thoughts are imlinked without 
searching, it becomes necessary to have an alternative interface for forgetting. Among the 
possible methods for accomplishing this result are dragging the thought to a forget icon or 
selecting a conmaand. The thought will then be forgotten along with all of its childward 
30 descendants that do not have other partners and are not the active thought To decide which 

thought to forget, the present invention makes a list that includes the thought to be forgotten and 
all thoughts childward of it. The present invention does not add the active thought to this list To 
remember the thoughts, the user can drag a thought to a remember icon or select a command. 

20 
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The thought and all its forgotten childward descendants will thereby be remembered More 
detailed algorithms for implementing these forgetting and remembering operations arc set forth 
in Figure 17. 

. Accessing Long Term Memory . To access thoughts that arc stored in long term 
5 memory, in some embodiments the user can interactively activate the display of long ten 

memory relationships for example, by means of a menu selection or function key). The display 
will then be refreshed, and thoughts related by long term memory relationships will become 
visible and are connected (as shown in Figure 11) to the central thought with a line, such as line 
1 1 10, of a different sort than that used for normal relationships. A long term relationship can 

1 0 then be recreated as a current relationship by using the "Relating Existing Thoughts" technique 
described above. In that case, the appropriate thought numbers (see Figure 2) are copied from 
past relationship lists 250 to the appropriate, current relationship lists 245. The appropriate 
thought numbers are then moved in the global long term and short term memory lists, and the 
display is once again redrawn. 

15 In an alternative embodiment of the present invention, each thought's headcase does not 

include a list of past relationships. Rather, each thought's headcase merely contains a flag 
identifying it as a forgotten thought or a present thought When a user interactively turns on a 
display of long term memory vwthin this alternative embodiment, forgotten thoughts and their 
relationships to present thoughts are added to the display, and severed relationships between 

20 present thoughts will not reappear. This alternative embodiment may offer certain advantages, 
including without limitation (i) presenting the user with a simpler, more readily comprehensible 
set of information regarding past relationships within the matrix; and (ii) reducing the 
complexity of the matrix's data structure and hence the computing resources used to operate the 
matrix. 

25 These same principles used for implementing long and short term memories are equally 

applicable for creating many other classes or levels of memory. A plurality of memory levels 
niay be created and thereafter any or all of the relationships stored at each level or in each class 
may be selectively chosen for viewing. For example, a user may elect to display only the top 
level, all levels, up to a specified level, or particularly designated levels having no immediate 

30 connection. 



Permanentlv Deleting a Thought It is also possible to permanently remove a thought 
from the matrix. This is accomplished by clicking on a line (such as line 1110) which connects a 

21 



wo 00/57257 PCT/USOO/06640 
thought which is already in long tcnn memory. When severing a relationship in thb manner 
results in a thought or thoughts becoming isolated, this thou^t or thoughts are removed from 
the global thought list and from the past relationships Ust 250 of the central thought. Although a 
portion of the thought data relating to a deleted thought will be erased, in one embodiment of the 
5 invention, the space occupied by the thought in the flat file database will be retained so that the 
software does not have to remove all references to it The present invention may be unable to 
remove all such references because they may occur on other lists or in other matrices which the 
software cannot control. Furthermore, comprehensive elimination of references may be 
computationally prohibitive, and leaving the thought's space in the flat file database requires 

1 0 relatively little storage space. 

Dividing a Matrix . When a user selects a link that will result in the isolation of particular 
thoughts, the user may optionally forget the thoughts, perraanenUy forget the thoughts, or split 
the matrix into two parts. Splitting the matrix into two parts wiU create a new thought that has 
the same name as the first thought to be isolated, but the document associated with this newly 

1 5 created thought will be a new matrix that is named after this first thought to be isolated. This 
new matrix wUl consist of all the thoughts which will be isolated in addition to the thought 
located at the position of the last link to be selected. That thought will reference the original 
matrix, and will be named after the original matrix. 

rri.atinp New Th "" p''* ^'"^^ T^^ . To define a new thought flag, the user 

20 interactively selects a thought and then enters a flag name and its default state. To define a new 
thought type, the user enters the name of the new type, its default flag states, and any fields that 
the type has. The new types and flags can thereafter be referenced by the user when creating new 
thoughts or changing thought properties. The type of a thought dictates which application 
program is used to edit the information associated with that thought AppUcation programs may 

25 be directly associated with a thought in the same way that the document window 360 in which a 
thought may be edited is associated with active thought 330. One embodiment of the invention 
assigns a preferred thought type to thoughts, but the user can override this thought type 
assignment by selecting another thought type either at the time of creation or by changing the 
default tijought type in the preferences. Acceptable thought types include any computer 

30 application capable of communicating with the present invention employing tiie methods 

disclosed herein. In some embodiments, the correct tiiought type for a document is determined 
by the file extension that the location specifies. 

Thought Pins . Thought pins are used to get instant access to comm nly used thoughts. 
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In the upper left comer of Figure 3 are two thought pins 370 and 375, labeled "Tlodin" and 
"Liquid Noise." Thought pins can be moved by the user to any location or deleted To create a 
new thought pin, the user simply moves the cursor (using mouse/control device 160), and clicks 
on or otherwise highlights the existing thought for wiiich a thought pin is to be created, and then 

5 selects a Xreate Pin" command or the like from an ensuing pop-up command menu (such as 
menu 1210). Alternatively, pins may be created by dragging thoughts to predefined zones within 
the display. Selectmg an existing thought pin (e.g., using mouse/control device 160 to position 
the cursor over the pin, then clicking the control devices*s button) makes the pin-represented 
thought into the new central thought of the current plex. For example, selecting thought pin 370 

1 0 ("Rodin") in Figure 3 would result in the plex transfonning into the plex displayed in Figure 1 3, 
with thought 370 ("Rodin") as the central thought. Note that thought pins may be represented 
internally by the numbers) of the thought(s) they reference and an explicit, user-specified 
display location. 

jvfessaping System . An embodiment of the present invention utilizes a thought 

1 5 messaging system ("TMS") to enhance interoperability between the present invention and the 
applications used to create, edit, and display documents; this messaging system plays a central 
role in matrix creation, as discussed below. AppUcations that comply with the TMS are referred 
to as "TMS-enabled" applications. Some embodiments of the present invention only interoperate 
with TMS-enabled applications. Other embodiments take advantage of the program-to-program 

20 interface features of operating systems such as Windows® by Microsoft to enable any 

application to be launched and operated within documents associated with thoughts, without 
need for a specialized TMS. Whether or to what extent a TMS is necessary to enable TMS- 
application interoperability depends partly upon the capabilities of the underlying operating 
system. A Windows® embodiment of the present invention, for example, allows the user to 

25 specify a list of Windows® applications which will create, read and write to files corresponding 
to thoughts of a certain **type." 

For instance, a spreadsheet application such as Microsoft Excel® would enable the 
creation of Excel-type thoughts wWch, when activated by the user, launch Excel, and load the 
Excel document associated with the specified thought Further, in one embodiment of the present 

30 invention, the display icons corresponding to thoughts are specialized according to thought type. 
For example, a thought of the Excel type would be symbolized by a display icon graphically 
depicting the thought as such an Excel type. A TMS may not be required under Windows® to 
enable the limited interoperability described in this paragraph. Methods of processing thoughts 
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are described in greater detail below. 

Even in Windows®, however, the incorporation of a TMS enables improved 
interoperability between the present invention and TMS-enabled application programs. TMS- 
enablcd applications permit users to Unk thought directiy to objects within TMS-enabled 

5 appUcation documents by dragging to the document windows. With applications that incorporate 
hyperlinks, the TMS allows the user to drag thoughts directly to those hyperlinks and associate 
with the objects that they reference. The TMS can be configured to work in concert with 
messaging systems native to the operating system. For example, Microsoft Windows® uses 
Dynamic Date Embedding CDDE")- 

10 Listing the program-to-program messaging capabilities of known operating systems, the 

TMS permits the present invention to provide specific instructions to TMS-enabled applications. 
For instance, the TMS may include the following core messages from the software of the present 
invention to the application. Software of the present uivention may request the identity of the 
document over which the mouse pointer presently resides; the application would respond with 

1 5 the current document name and file location using the name and address symbol of the native 
operating system, or the hyperlink's name and file location. The present invention may signal 
the activation of a particular thought, and the present invention will provide the number, name, 
and location of this tiiought; if a thought is being created, the present invention wil' also provide 
the template parameter(s) corresponding to this new tiiought; in response, the application wUl 

20 save Uie current document and load or create the new document if Uie new document is of the 
same type, and if creating the new document, will use tiie template parameter to open the default 
document The present invention may request that the application move its window to tiie top; in 
response, the application wUl make its window visible over any other applications. Finally, the 
present invention may request that tiie application move its window in a requested manner, save, 

25 rename, or relocate its document; in response, tiie application will do so. as instructed by tiie 
software of the present invention. 

The TMS may also include by way of example tiie following core messages fi?om 
applications to tiic software of tiie present invention An appUcanon may adc ttie present 
invention to identify die active tiiought; tiie present invention will respond witii tiie active 

30 tiioughfs number, name, and location using TMS-specific symbols. An application may ask tiie 
software of the present invention to activate a tiiought with a specified number, name, and 
location, and tiie present invention will do so. An appUcation may ask what tiiought corresponds 
to a particular number, name, and location: tiie software of tiie present invention responds wiOi 
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the thought's number, name, and location, or will return "false" if the specified thought does not 
exist An application may ask the software of the present invention to create or link a specified 
thought, related by designated child/parent links to another designated thought; if requested, the 
software of the Fcscnt invention performs the specified operation. Finally, an application may 
•5 teU the present invention that the appUcation is TMS-enabled. and will provide the information 
needed to start the appUcation, the application's document types, and their respective 
descriptions; if so, the present invention stores this information and adds that appUcation's 
document types to the list of permissible thought types. 

/^ntnmatic TTiouoM Recognition . The present invention can activate thoughts based on 
10 commands sent from other application programs as well, including without limitation, the editor 
or calendar applications. For instance, the editor may contain a word that is also a thought name. 
Using the TMS, the editor can identify the specific word or words as being a thought and 
automatically highlight them on the display. Alternatively, the present invention could be 
queried when the user selects one of these words. When a word is successfiiUy identified as 
15 being a thought and is selected by the user, the application may then send a message to the 
present invention requesting the activation of the specific thought. A similar process may be 
used to recognize and activate thoughts through any TMS-enabled application. 

rrpatin p Thought Plexes . As described earUer. thought plexes are the graphical displays 
of a group of related thoughts, consisting of a central thought and any parent, child, jump, and 
20 sibling thoughts. There is always at least one thought plex. In one embodiment of the present 
invention, additional thought plexes can be created by using the control device 160 to position 
the cursor over any thought other than the central thought, and dragging the selected thought to 
the desired locaUon of the new plex. Each time a user creates a plex. that plex is added to the 
screen display along with the other plexes previously presented on the screen display (see Figure 
25 9). The figures demonstrate an example of the manner in which a new plex may he created. First, 
in Figure 3. a user interactively selects the thought 314 'Projects" to be a new central thought by 
using control device 160 to position the cursor over diat thought then selects the thought by 
clicking and holding a button on the cursor control device. Hie user then employs control device 
160 to move the cursor to the desired location of the new plex and releases the button. Figure 9 
30 demonstrates the screen display which results. Plex 920 has been added to the screen display, 
with the thought 914 rProjects") as the central thought of new Plex 920. The Plex is the on- 
screen interface to the matrix in which data is stored. 

/Automated Matrix Creation. Matrices may be created either on c mmand or. in one 
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embodiment of the present invention, they may be created on the fly. When created on 
command, matrices are static and wiU not change unless a user explicitly commands that a 
change be made. When created on the fly in response to user inputs and navigation, by contrast, 
a matrix will change as the information represented by that matrix changes. 

5 Automated matrix creation has many potential applications, including the automatic 

creation of a matrix representing a standard Werarchy such as those commonly used in directory 
structures. In this application, the software of the present invention begins at the root of the 
hierarchy and creates a child thought for every file and folder, and then goes into each folder and 
repeats the process! This recursive process effectively generates a plex representing a directory 

10 structure, and as discussed above, can be performed on the fly or as the user navigates amongst 
thoughts. The present invention begins by displaying the current thought within the hierarchy. 
Each item within the presently displayed thought is displayed as a child, and children that 
contain other items are displayed with a highlighted child gate to indicate the same to the user. 
The level of the hierarchy that contains the current item is displayed as a parent, and the other 

1 5 items within the level containmg the current item are displayed as siblings. 

The automated conversion of a standard hierarchy to a matrix within the present 
invention allows users to subsequently modify the resulting matrix in a nonlinear 
nonhierarchical manner, thereby creating a nonlinear nonhierarchical information structure with 
a minimum of effort. Furthermore, the abUity to view and activate siblings may be valuable 

20 irrespective of whether nonhierarchical relationships are established within the matrix. 

The present invention additionally may automatically generate matrices reflecting self- 
referencing hierarchies, such as those used to organize the Worid Wide Web CWWW"). When 
an item in a self-referencing hierarchy is encountered and has already been added to the matrix, 
the present invention links to the existing thought rather than creating a new thought This 

25 technique may result in 'Swap around" structures and multiple-parent structures that actually 
exist in a self-referencing hierarchy and can now be displayed with the advent of the present 
invention. 

Similariy, the present invention permits a matrix to be automatically generated from a 
hypertext document This document becomes the central thought, and the linked items within the 
30 document become children thoughts. Those linked children may subsequently be explored in a 
similar manner. In cases where hypertext uses somewhat predictable link names, the present 
invention may link thoughts in a more context-sensitive manner. For instance, files located on a 
remote computer or Internet URL may be displayed as jump thoughts, and files which are 
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disposed in a hierarchical directory location above the current directory may be displayed as 
parent thoughts. This method for automated generation of matrices may be restricted so that it 
does not create overly cumbersome plexes. For example, it may be designed so that it does not 
create thoughts relating to files located on remote machines. 

A matrix may also be created on the fly to reflect a user's navigation within a collection 
of hypertext content such as the Internet's World Wide Web. In this embodiment, each 
hyperlinked document selected by the user is linked as a child to the document fit)m which it 
was selected, and the hyperlinked document becomes the active thought Once such a structure 
has been created, the "back" command may be used to activate the parent thought, thereby 
moving the user to the previous page. Similarly, the child thought is activated if the user selects 
the "Forward" command. The added benefit to using this matrix arises in cases where the user 
selects a different hyperlink rather than the "Forward" command; in such cases, the new 
hyperlink is added as a child thought. Also, if a user navigates to a page which has already been 
visited, there will already be a thought representing that page which will be linked to as a child. 
In this fashion, users may generate a matrix that is exceptionally useful for tracking browsing 
history relative to traditional methods. 

Furthermore, matrices representing the results of a database search may also be 
generated. Such searches are typically performed in response to words input by the xiser, and the 
results are usually displayed in an ordered list arranged by some measure of fi-equency or 
relevance. One embodiment of the present invention parses such lists to identify other common 
words or themes from among the results. In accordance with the result of this parsing step, a 
matrix is created with the query as the central thought and with the other common words or 
themes as child thoughts. Results that do not share common words or themes are displayed as 
children. When a child thought is activated, if the child has a common word or theme, the results 
sharing that conuhonaltty are broken down again. If the child is a result, then resxilts that are 
contained within that result are displayed as children, and items related to that result are 
displayed as jumps. 

Moving Thought Pins and Plexes . In one embodiment of the invention, thought pins can 
be repositioned by dragging them with the mouse or other control device. Thought plexes can be 
repositioned by dragging their central thought with the mouse or other control device. Thought 
pins and plexes can be deleted by dragging them off of the display. Eliminating a plex from the 
display does not result in any thoughts being forgotten. Forgetting involves a different user- 
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interactive process discussed above (see "Severing Relations Between Existing Thoughts")- 

PpciyinpnThnughtPlex . In one embodiment, a thought plex can be sized by dragging 
the circle which sunounds the central thought Making the circle bigger makes the entire plex 
bigger and vice-versa. 

5 rhanging a Thought Pin . In one embodiment of the present invention, a thought pin can 

be made to reference a different thought simply by dragging the desired thought onto the pin. 

The Matrix Freeze . In response to a user's request or in response to a regularly scheduled 
system request for backup, a "Freeze." in one embodiment, saves the state of all parts of a matrix 
at a given point in time, copying all die information to a read-only format for later use. 

IQ Prncessing Thoughts 

Ma piit^P Thought Files . By default, a thought does not have a matrix or operating system 
file location specified when it is created. If the user selects an active thought without a specified 
location, a Windows® embodiment of the present invention's software opens a dialog that 
allows the user to select the type of file to create. After the user selects a file type, that 

1 5 embodiment of the present invention uses standard operating system methods to create a file of 
the selected type and thereafter names the file by appending the file type to the name of the 
thought. The file associated with that thought is placed in a folder (_bm folder) specified by the 
present invention (discussed below) and is opened immediately. The file name and the thought 
name an independent, and the renaming of a thought does not compel the renaming or 

20 relocating of its file within the network or operating system. Therefore, if the file is shared, other 
programs and users not operating the present invention will still be able to locate it. 

OnpnmP a Thought . A thought's headcase file may specify an item a thought document) 
within a traditional file system that is associated with the thought. This thought document may 
reside in the storage ^stem of a local computer, or may be retrieved through a network, 

25 including without limitation a LAN or die Internet When a thought is activated, the present 
invention may request that the operating system open the thought document associated with the 
selected thought When a thought document is saved, it will typically be stored by most 
application programs to the file location firem which it was loaded. This location is, of course, 
the location that the thought references. Accordingly, a user may both open and close files from 

30 the present invention without navigating a traditional operating system's file reference means, 
and irrespective of the storage location of that file. 

A user may optionally limit automatic thought document loading to those documents 
having specified file types or residing in certain locations. File extensions typically may be used 
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to distinguish among file type. For example, file location, usually placed before the filename and 
separated from the fUename by a backslash, allows a Windows® embodiment of the invention to 
discern the location f each file; periods and forward slashes allow a UNIX or Internet 
embodiment the same utility. 
5 Fditing Thoupht Documents. Each thought's document contents are displayed in 

document window 360, as iUustrated in Figure 3. When the current thought is changed, the last 
thought's document is saved (unless otherwise directed by the user) if necessary and then the 
new current thought's document is loaded automatically. The user never has to issue "save" or 
"open" commands to access thought documents, nor docs the user need to expUcitly identify or 

1 0 invoke an editor or other application program to process the thoughts. These operations are 

performed automatically by the present invention, seamlessly and transparently. When a thought 
is activated by the user, the present invention saves the previously active thought, if it has 
changed, then loads the newly active thought. Well-known computer programming object 
technologies, including without limitation Microsoft's Object Linking and Embedding rOLE"). 

1 5 allow the document to make references to data which is created and edited by other programs. 
Using standard operating systems calls, the present invention can display and allow the user to 
edit these objects with the appropriate computer programs. In addition, the document may also 
store references to the location of other documents on the storage systems available to the 
computer, aUowing the user to open them with the appropriate computer programs using a more 

20 traditional operating system method. 

T ;.^ |^inp Remote Files . Using the TMS or another method of inter-process 
communication, the present invention can request an application to identify the file it presenUy 
has open. The availability of this technique aUows the present invention to create thoughts 
representing files that arc open in other application programs. In one embodiment, the user may 

25 do so by simply dragging a link from a thought and releasing the selection button on the cursor 
control device when the pointer is situated over the desired application window. Upon the 
performance of these steps, the present invention queries the appUcation for the identity of the 
file it has loaded, and the present invention creates a thought and sets the name and location of 
this thought in accordance with the appUcation's response to the present invention's query. The 

30 thought Qn this case, the acUvc document in the application window) is thereby linked to the 
gate fix>m which the user dragged the cursor. For instance, if the document is a Hypertext 
Maricup Language ("html") Worid Wide Web site stored remotely on the Internet being viewed 
using a web browser applicaUon such as Navigators by Netscape, the present invention wiU 
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name a new thought based upon the doc\iment*s Internet URL (Uniform R source Locator) or 
the contents of an html 'title" tag. When, in later use, a user reactivates this thought, practicing 
methods described above, the present invention will launch the user*s preferred web browser 
application, and request that the web browser download the html file from the remote URL. 

• 5 pelaved Loading . In some instances, the loading of the contents of a thought may require the 
expenditure of considerable computing resources, and it may be desirable to allow the user to 
navigate through a series of thoughts without loading the content of every thought through 
vsiiich a user passes along the path to reaching a particular destination thought This functionality 
is implemented in accordance with the flow chart illustrated in Figure 22. and allows the passage 

10 of a duration of time noticeable to the user before loading the contents of a selected thought 

More particularly, upon the selection of a thought by the user at step 21 1 0, the plex is redrawn in 
step 2112 using the animation techniques discussed herein, and a loading delay procedure 
initiates. One embodiment of the present invention uses an expanding circle to appraise the user 
of the status of the loading delay. At step 2114, this expanding circle begins as a small circle 

1 5 oriented within or about the area representing the central thought, and the circle expands with the 
passage of time. At step 2 1 1 6, the circle is enlarged and is redrawn. Next, at step 2 1 1 8, the 
method queries whether another thought has been selected. If so, the routine returns to its 
beginning, step 21 1 0, and the loading delay process is initiated with respect to the newly 
selected thought. If another thought has not yet been selected, in step 2120 the routine queries 

20 whether the circumference of the circle has grown to reach the periphery of the present 
invention's window in which the present plex is graphically displayed. If so, the routine 
generates and sends a message to load the contents of the selected thought in step 2122. If not, 
the routine returns to step 21t6 where the circle is enlarged and redrawn, and the routine 
continues. With this method, thoughts are not loaded during a predetermined period of time after 

25 their selection, and are not loaded if another thought is selected during this time. This delayed 
loading may be used to allocate optimally the computing power available to a user. 

Some prior Internet browsing means require every Worid Wide Web site to incorporate 
user navigation methods within hypertext documents. Those methods inefiBciently force users to 
download irrelevant information, merely for the purpose of navigating through it. One strikingly 

30 powerful application of the present invcntion*s delayed loading technique allows expedited 

navigation through Internet pages or files without waiting for the content of intermediate pages 
or files to load. 

Changing Thought Prorerties . Thought properties such as name, flags, priority, and 
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category can be changed using a thought properties dialog box. such as dialog box 710, which is 
accessed by the user employing mouse/control device 160 and/or keyboard 1 50 to select a 
particular thought and then the thought properties dialog box. In some embodiments, the 
properties dialog box remains visible at all times, and changes to reflect the properties of the 

5 current central thought 

pditinp Thought Fields . Thought fields can be edited in a dialog box or window such as 

1410 in Figure 14. In one embodiment, the field names are displayed to the left and their 

contents to the right. Thought fields are automatically loaded and saved, in the same fashion as 

are the contents of thought documentsrinvisibly to the user eve^ 
1 0 modified. All thoughts of a certain category possess the same available thought fields, which 

fields are defined by the user in establishing and modifying thought categories (see above, 

"Category*0. 

In one embodiment, every thought category 240 possesses at least two fields. Those 
default fields are the •'Name" field and the "Key Words" field. The contents of these default 
1 5 fields are identical to the contents of the properties called *'Name" and "Key Words" 
respectively. 

Rewinding and Renlavinff Previous Operations . An event list is created automatically by 
the present invention, as the user works. The event list is a recording of each action the user 
takes. It stores how to undo each action and how to repeat each action. At the user's request, the 
20 present invention can then use this information to "rewind" and "replay" the actions of the user. 

Thought Lists . Internally, within a computer, the present invention stores thought lists as 
a list of thought numbers. To the user, the present invention displays as a list of thought names. 
One embodiment of the present invention keeps a list of all short term memory thoughts and 
long term memory thoughts. In addition, a list of thoughts is created for each defined thought 
25 type. Lists of thoughts can also be manually created (see below, 'Trains of Thought" and 
"Searching"). The user can activate a thought in a list (make it central in the current plex) by 
clicking on it. Thought lists can also be used to perform group operations on thoughts such as 
printing, changing properties, or even saving (to save only a selected portion of the matrix). One 
embodiment used to maintain thought lists, using bitmap lists, is discussed in the "Determining 
30 If Thoughts Will Be Isolated" section above, 

The Past Thought List One special example of a thought list is the past thought list. 
Figure 3 illustrates how a past thought list 380 can be created automatically as the user works. 
Each time the user changes the current thought, the number of the new central thought and the 
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time it was activated are added; when the user stops working, a null and the time are added. In 
this manner, the present invention tracks the user's work with reference to the timeframe in 
which it was performed, and this information is recorded for later reference. In the one 
embodiment, it is possible to display the past thought Ust as a Ust (such as past thought Ust 380) 
5 of thoughts which scrolls along the bottom of the display as the user activates thoughts. For 
example, each time a user activates a separate thought, the previously activated thought is placed 
at the right-hand end of past thought list 380 pushing the older dioughts to the left of the screen. 
The oldest thought that caimot fit on screen is eliminated from view from the left-hand end of 
pastthoughtlist 380.Thislistmay be scrolled t^ disappeared. 

1 0 Trains of Thought Another special example of a thought list is the '*train of thought." which lists 
a series of thoughts in a particular sequence as desired by the user. A train of thoiight can be 
created by simply navigating through the desired thoughts in the same order as the user wants 
them to appear in the train of thought. This will automatically cause the desired sequence of 
thoughts to become part of the past thought list, as noted above. As shown in Figure 1 1, the user 

1 5 then interactively selects the desired section of the past thought list using mouse/control device 
1 60. In the case of Figure 11 , the user has selected "Projects" and *7^atrificial"-- the two most 
recent thoughts- for inclusion in a train of thought. The user then interactively selects the Create 
Train command 1 120 by using a pull down menu, fimction key or similar means. In response, 
the selected sequence of thoughts is copied to a new thought list and the user is asked to name it, 

20 thus creating a new 'train of thought' thought list 

Trains of thought can be used for accomplishing tasks that involve a number of pre- 
existing parts. For example, an attorney might use a train of thought to assemble a number of 
pre-existing sections of text (stored in separate thought documents) into a new contract, or an 
engineer or computer programmer can use trains of thought to assemble a new computer 

25 program out of a pre-existing library of subroutines. 

In one embodiment of the invention, a selected train of thought may be identified in a 
plex so that it is easier for a user to follow. Specifically, the active thought in a train may be 
identified,, and the next and previous thoughts on the train may be highlighted in the plex. If the 
active thought is not in the train, then any thoughts in the train are highlighted. Optionally, 

30 arrows may also be drawn between thoughts in the plex to reflect the order of the train of 
thought 

Searching . Thought lists can be filtered or "searched" according to thought category, 
priority, name, flags, fields, or any other subject stored within a thought's headcase file or 
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document. This allows the matrix to be used as a searchable database. For example, one thought 
type might be the type *Terson," which might include the attribute "City.*' Each thought of the 
Person type would then be assigned a specific "City" value by the user. Users could then request 
a search of the matrix for all thoughts involving persons they know who liv in a certain city, by 
5 requesting a display of all thoughts on the "Person" type list, filtered as to those whose "City** 
attribute equals the desired value. 

Similarly, the present invention enables users to create project plans, daily agendas, or 
to-do lists or other task-oriented thought lists and create relevant thought lists. First, the user 
assigns priority levels (e.g,, "urgent," "important," "unimportant") or flags (e.g., "completed" or 
10 "incomplete**) to thoughts as they work (see 'Changing Thought Properties" above). The present 
invention enables users later to create a to-do list, for example, by searching for thoughts 
associated with a flag set in the "incomplete" position and a priority level of '^irgent*' The 
matrix search engine operates in a method similar to those widely used in conunercially 
available database programs. 

15 

Layers . A set (or sets) of layers may be applied to every docxmient in the present 
invention. Subsequently, these layers may be selectively activated and deactivated. Layers that 
are "on" are displayed and available for editing, while layers that are "off' are hidden. Examples 
of layers can be found in many applications well known in the art such as Autocad® by 
20 Autodesk and Photoshop® by Adobe. 

Usage statistics . Usage statistics suitable for keeping track of billable time, productivity, 
work habits or efiBciency may be generated and stored for each thought as the user works on that 
thought, according to the system clock. These statistics include time of creation, time of last 
modification, time of last access by user and the time (if applicable) at which the thought was 
25 "forgotten." Each thought also stores the total number of seconds the user has so far spent 
processing it, the number of "events" (keyboard and mouse clicks) that occurred, and the 
thought's modification history (e.g., a list of all dates when that thought was nciodified and how 
long each such modification took). 

In some embodiments, the system supports interactive conmiands for requesting the 
30 display of these usage statistics. For example, in one embodiment, a user can request to view 
usage statistics falling within a given time period. The present invention's preferences can be set 
so that the display reflects different aspects of the usage statistics. Figure 3 demonstrates how 
one embodiment of the present invention can display usage information automatically. By 

33 



wo 00/57257 PCT/USOO/06640 
default some embodimects show a "C* next to each thought which was recently created (380); 
an '^A" next to each thought which was recently accessed (380, 385); an 'X" next to the last 
active thought (390, 395); and an "M" next to each thought which was recently modified (riot 
illustrated). Alternatively, usage statistics may be reflected by differences in the color of 
5 thoughts, or by the addition of markers. For example, thoughts that have not been accessed for a 
relatively extended period of time might be displayed in a color such as gray that is less likely to 
attract the attention of the user. 

Undoing and Redoing . Undoing and redoing of operations may be supported by an 
internally stored event list which keeps track of how data is affected and what is necessary to 
1 0 undo the effects of each event. When something is undone the undo event is recorded to the redo 
list to enable redoing. 

Calendar Schedulinp . By storing thought numbers in events, appointments, schedule 
data, or other time-based items, it is possible to associate time-based events with thoughts. A 
calendar can then be iised by the user to keep track of events and link related thoughts to the 
1 5 events. For example, in one embodiment, rather than displaying thoughts graphically in plexes, 
thoughts can be displayed on a calendar as demonstrated in Figure 15. For example, the calendar 
event 1510 0*9:00 am meeting with Liquid Noise project team") may be associated with "Liquid 
Noise" thought 960. Some embodiments of the present invention permit a user to create that 
association by using the mouse/control device 160 to draw a line cormecting the calendar event 
20 1510 and the desired thought 960. When a user interactively selects calendar event 1510, thought 
960 becomes the new central thought (as illustrated). 

In addition, thoughts may be associated through calendar events with computer program 
operations. For example, if calendar event 1510 were associated with an alarm program, then at 
9:00 am, the alarm would soimd, and the present invention could also be configured to display a 
25 reminder message, or activate **Liquid Noise" thought 960 as the new central thought 

Preferences . Particular preferences relating to the operation of the presently disclosed 
technique may be selected by the user. The user may designate, for example, the set of colors to 
be used in the graphical representation of the interface and content organized thereby, the speed 
of the animation, the loading delay, the levels of thoughts to be displayed (e.g., "wbich of die 
30 distant thoughts), and the wallp^er. Also saved to this table is information about the positioning 
of the various windows comprising the user interface and the information organized thereby. 

Furthermore, all necessary information about the location of the present computer is 
stored with the preferences. Storage of this location information allows the user to move a 
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matrix to another computer while preserving one's ability to access the files referenced by that 
matrix, provided that the files resident on the remote computer remain accessible from the 
computer to which that matrix is transferred. 

NetwnHc-Related Features 
5 Some embodiments of the present invention include features that enhance operabihty of 

the present invention in connection with both local and remote networks, including the Internet, 
as discussed below. 

Remote Access to a Matrix . Some embodiments of the present invention allow the use of 
a matrix with a second computer, although the matrix was originally created on a first computer. 

10 To the extent the files on this first computer may be locally accessed, for example through a 

local network, the present invention wiU simply access these local files. However, if the files on 
the first computer are not locally accessible, the present invention can copy such files fi^om the 
first computer to the local computer; so that this change is incorporated into the operation of the 
present invention, the present invention will additionally change the location of the computer 

1 5 with the file (to the second computer) so that the file may be locally accessed. 

Sharing ThonpHt Documents . With most current operating systems, document sharing is 
based on the location of a file within a hierarchical file system. The present invention locates 
thought documents according to the desired sharing properties. When the user sets the sharing 
properties of a thought, the document is moved to a folder that possesses the requisite sharing 

20 properties. When thoughts arc created, they are assigned the same sharing properties as the 

thoughts from which they are created. The user may optionally change the sharing properties of 
several thoughts by using the List manager to create a list of thoughts and subsequently 
assigning the desired sharing characteristics to the thoughts on this list 

Version Control . By associating a thought with a special document type that stores the 

25 names of multiple documents, a thought may be made to contain a plurality of documents. The 
initial steps for creating a thought that contains more than one version of a document are the 
same as those normally used for creating a thought When the user wishes to create a second 
version, however, the create version command is interactively selected, and the user can name 
the new version and select its type. The user may alternatively select the default type for the new 

30 version, which is that of the old version. With this process, the location property is changed to a 
new file which lists the versions of the document and contains a name and location for each 
version. In the thought's data within the hcadcase, the current version number is set to the 
current version. The names and locations of different versions of a thought can be changed using 
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the thought properties dialog box. A version control is displayed in proximity to an active 
thought having multiple versions. The user may select this control to display a list of all versions 
of that active thought, and may thereafter select a desired version from this list 

Selection Feedback . One embodiment of the present invention facilitates the user*s 
navigation through the matrix by monitoring the position of the user's cursor or pointer and 
highlighting the elements on the display that the user could select given the present position of 
the user's pointing device. In other words, this feedback system indicates the elements that 
would be activated upon the depression of a selection button resident on the user's pointing 
device, in view of the present position of the pointing device. For example, a gale, link, thought, 
or any other display element could change color to indicate that the element would be selected if 
the user depressed a mouse button. 

Matrices Referencing Other Thought Matrices . A thought type can be a matrix, so it is 
possible for one matrix to reference another matrix. For example, in one embodiment of the 
present invention, when an active thought is itself a matrix, a second instance of the software of 
the present invention is started and it loads the appropriate matrix. This matrix is then displayed 
in a separate window. The ability of a user to create several matrices makes the present invention 
adaptable to a wide range of information storage needs, and accordingly diinmishes the requisite 
complexity of individual matrices in cases suitable for multi-matrix storage schemes. In most of 
these cases, this added flexibility would likewise reduce overall system complexity. 
Furthemiore, such an arrangement advantageously facilitates sharing of matrix data, as for 
example, a computer network administrator can more readily assign access privileges to single 
or multiple discrete matrices. 

Linking Matrices . One embodiment of the present invention allows the user to link 
matrices together. In particiilar, when two matrices are displayed in separate windows, the user 
may copy a second matrix into a first matrix simply by dragging (with the cursor control device) 
from the first matrix to the second. The matrix that is dragged, the first matrix, is thereby linked 
to the active thought of the matrix to which it is dragged, the second matrix. The two matrices 
and all of their linked thoughts are thereby incorporated into the first matrix. Each of these 
thoughts fi^m the second matrix that are copied into the fu-st matrix must be reniimbered during 
the copying process so that they do not conflict with previously*existing thoughts associated 
with the first thought matrix. 

Matrix Sharing . A token system is used in one embodiment of the invention to allow 
multiple users to simultaneously modify a single matrix. In accordance with this system, when a 
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user requests a modification, all other users arc not pertnitted to make modifications untU the 
matrix is updated to reflect the first user's modification. In a multi-user environment, the past 
thought list and other usage data may be stored once for each user, and optionally may be unified 
to produce data for all of the users. 
5 Semi-Hierary h^ cal Arrangement In some instances, a user may prefer to arrange portions 

of their information in a traditional hierarchical manner. This may occur, for example, if the data 
is particularly susceptible to storage in a highly-structured manner and if the user has some 
preexisting familiarity with a hierarchical information storage structure. One embodiment of the 
present invention therefore allows users to store information in a purely hie^ structure, 

10 and to access this data through traditional operating system methods. This traditional storage 

structure, however, may be integrated with the storage structure of the present invention to allow 
the present invention to store other data. For example, a company may wish to store information 
organized by the management divisions within the company. The company could create a set of 
folders for each division and then a second level of folders for each employee within a division; 

1 5 then, matrices may be placed within each employee folder, for example, corresponding to each 
individual employee. 

Just-in-Time Server Model for Sending Plexes . When a large matrix is created and 
subsequently must be accessed over a communications channel having a relatively narrow 
bandwidth, it is possible to send only data that is relevant to a user's location within that matrix. 

20 This is accomplished with client/server computer network architecture. In one embodiment, the 
client software of the present invention identifies for the server the presently active thought. The 
just-in-time server software of the present invention then sends the numbers of all thoughts 
within the present plex, as well as the numbers of all thoughts that would become part of the 
plex upon the selection of any thought within the present plex. In other words, the server wiU 

25 send the number of the active thought, its children, parents, jumps, and siblings, as well as the 
children, parents, jumps, and siblings of those thoughts. This list of numbers is used by the client 
to determine which thoughts are already in the clienfs cache. Those thoughts that arc already in 
the client's cache should be removed fi-om the list, and then the list is returned to the server. At 
this point, the server sends the data corresponding to all thoughts remaining on the list. The 

30 above-described cycle is repeated upon the selection of a new central thought 

In another embodiment of the invention, an alternative procedure may be used to 
implement client-server communication. Specifically, on a client's first interaction with a server, 
the client sends an initialization message to the server that includes its location on the network, 
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The server creates a blank list that may be of the same type as the ThoughtList used to identify 
isolated thoughts, and uses this list to identify the thoughts akeady sent to the client Then, for 
each thought activated by the client's user, the client identifies the presently active thought to the 
server. In response, the server generates a list of thoughts having a predetermined relation (e.g., 
5 within a set number of generations) to the active thought, removes from the list any thoughts 
already present on the client, sends to the client the data corresponding to all thoughts remaining 
on the list, and adds these sent thoughts to its list of dioughts present on the client 

In accordance with these methods, the present invention minimizes the extent to which 
data is unnecessarily downloaded," and assures that data relating to the next-selected plex will be 
1 0 immediately accessible. The above-described methods enhance performance by minimizing the 
delay inherent in a client-server system constrained by a narrow bandwidth telecommunications 
facility. 

Integration With Hvt>ertext . One can incorporate matrices into hypertext by embedding 
so that the client software of the present invention is launched and displays the file when the 

1 5 hypertext page is loaded by a browser program. Alternatively, the file could be loaded and 

displayed in response to the selection of its link by the user. Furthermore, it is possible to define 
a matrix usiiig text that is transferred to the present invention in a format such as: [Thought 
Number, Thought Name, Thought Location, Parents, 0, Children. 0. Jumps, 0]. Such a format 
could be embedded and created using a typical hypertext editor, and the present invention would 

20 simply convert this format into the normal file format and display it Hypertext languages could 
also be modified to be more similar to the matrix structure simply by identifying links as either 
parent, child, or jump links. Such a modification would allow the present invention to base 
matrix creation directly upon a reading of the hyperlinks, without the need for an intermediate 
format conversion step. 

25 Alternative Matrix File 

In an alternative embodiment of the present invention, the characteristics of the above.- 
described matrix and Headcase files may be modified to permit improved functionality for 
certain applications. The data architecture of this modified file, hereafter referred to as the ".bm" 
file, is illxistrated in Figure 16. As can be seen, the .bm file contains additional elements arid a 

30 different organizational structure than the headcase file illustrated in Figure 2. While multiple 
file structures are clearly permissible, the selection and implementation of a single standardized 
structure may be particularly advantageous; the use of a universal file format allows data to be 
transferrable across different operating platforms. For example, a matrix created in a Microsoft 
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Windows®* operating environment could be read by a UNIX-based version of the present 
inventioiL With this background, the principal differences between the .bm file and a generic 
matrix file are addressed below. 

The .bm file stores all information describing the interrelation among thoughts. The file 
5 may be named by the user, and is assigned the extension ".bm." The present invention also 

creates a folder that is assigned a name similar to the .bm file, except that the folder is given the 
extension "- bm" A preponderance of the .bm file is composed of a flat file database. This 
structure allows thoughts to be located based on their numbers. As Figure 16 illustrates, a 
thought' s location in the bra file is equal to the size of the header information, added to the size 

10 of the preference information, added to one less than the number of the thought multiplied by the 
size of a thought ("thought size' in the header information). 

The bm folder . All information specific to a matrix that is not contained in the .bm file 
is stored in the_bm folder. This folder may contain an index file for locating thoughts wthin the 
thought data, using cither thought name or location. It may also contain a variable field length 

15 database for storing information relating to thoughts having unpredictable sizes, notes, and 

perhaps even files and versions of files. These notes may be created by a simple word processor 
capable of including OLE objects and thus pictures, spreadsheets, and other data. In one 
embodiment, notes relate to individual thoughts and are automatically loaded and saved as the 
associated thought is activated and deactivated. The _bm folder may also contain the past 

20 thought list, as well as the list of parentless thoughts. 

Intemal and External Files . Intemal files, such as files located in the _bm folder, are 
deleted when their thoughts are permanently forgotten. Intemal files are convenient because they 
are aggregated at a single location and are easily copied or backed-up along with the remainder 
25 to the _bm folder. External files are those not in the _bm folder, such as those in another folder, 
or stored remotely on a computer network including, for example, the Internet As distinguished 
from internal files, these external files are not deleted when their thoughts arc permanently 
forgotten because they could have some other use. 

The user can request that an external file be converted to an internal file by selecting a 
30 *To Internal' command and specifying a location. In response, the present invention will then 
move the files to the specified location and will change the location of the thought file. The user 
can similarly use a "To External' command to convert an intemal file into an -extemal file stored 
at a specified location. The present invention implements this change by moving the file to the 
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specified location and changing the location of the thought file. If the present invention attempts 
to create or move a file into the _bn) folder, but the file name is already in use, the present 
invention will add a number to die end of the file name and will continue to increment ttiat 
number until the conflict is resolved. 

♦ 5 Communications Amongst Content Users 

Another aspect of the present invention permits network users to identify and 
communicate with other users of shared content For purposes of illustration, an embodiment 
connected with the plex, matrix, and thought structures of the current invention is disclosed in 
this section. Note, however, that this aspect of the current invention can be implemented in 

1 0 conjunction with any set of segmented data that is shared amongst multiple clients or users. 
Figure 26 illustrates the requirements of such a shared data structure and computer network. 

Minimally, the structure includes: client 2610. a computer running network 
communications software capable of storing a unique and persistent client identification number 
(^persistent I.D.") and capable of transmitting that persistent ID. to a network server 2620 each 

1 5 time it activates a different thought to be the new central thought: a network server 2620 

computer capable of transmitting and receiving data to and from multiple computers linked in a 
network of the type known in the art, a central navigation data base 2630 capable of storing an 
entire mauix of thoughts along with a thought table 2640 which associates the persistent ID.'s of 
clients currently accessing thoughts as central thoughts along with the thought numbers of those 

20 central thoughts, and a user table 2650 of persistent I.D.'s and optionally other user data related 
to those persistent LD.'s; and optionally other clients or neighbors 2660 also identified by 
persistent I.D/s and capable of retrieving data from the network server 2620 relevant to client 
2610, other neighbors 2660 and the current central thoughts of client 2620 and those other 
neighbors 2660. 

25 Registering with the Network Server . In one embodiment, the client obtains its 

persistent ID. from the server following a registration process as follows: 

Client 2620 selects a user name (or alternatively a usemame is assigned by the server). 
That usemame may be the same as the persistent I.D., or for user convenience, the user may 
select or assign a imique human language usemame that is dififercnt from the persistent I D. 

30 Optionally, in registering, the client software may also request from the information relating to 
the computer or user's communications means such as street address, phone number, electronic 
mail address, IRC or chat software, internet telephony software, video or conferencing software 
or any other protocols or means necessary for conveniently enabling neighbors 2660 to 
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communicate with the client 2610. The client software may also optionally request other 
information relating to the computer or the user at client 2610. Upon receiving this user data, 
server software at network server 2620 checks with user table 26S0 for an available tmique 
persistent ID., and assigns that persistent I.D. to that client 2610 by creating a record imder that 
5 persistent I.D. within the user table 2650. The network server 2620 then responds to client 26 1 0 
by sending the persistent I.D. to the registering client 2610 and software at client 2610 stores 
that imique persistent I.D. for later use. 

Sharing Content Usage Data Amongst Users . Once sxich a persistent ID. has been 
assigned, the network server 2620, in combination with the central navigation data base 2630, 

1 0 monitors the current central thought of the client and makes that and the client's registration data 
available to the neighbors 2660 as illustrated in the dialog illustration of Figure 28. Any time 
client 2610 activates a different central thought as described above (See, Matrix Navigation, 
above,) at step 281 0, that client 2610 sends a message to the network server 2620 that a client 
with unique persistent I.D. 'X'* has activated thought number "X' as its new central thought 

15 At step 820 network server 2620 updates the thought table 2640 to reflect a new 

persistent ID. ^X" associated with thought number *X' (2820). Optionally, by implementing the 
methods described above, that server 2620 can query that client 2610 to determine which new 
thoughts within the resulting plex are not cached with client 2610 and at 2830 transmit those 
thoughts to the client 2610. (See, Just-in-Time Server Model for Sending Plexcs, above.) 

20 Next, using known point to multi-point communications techniques, at step 2840 a 

preferred embodiment of the present invention will send back to the client 261 0 and, as 
applicable, the neighbors 2660 data regarding the quantity and/or identity of all neighbors whose 
current central thoughts are witfiin the plex. This data can be transmitted to the client 2610 each 
time that client 261 0 activates a new central thought, each time any neighbor 2660 activates a 

25 new central thought within the current plex, at regular time intervals, or upon explicit request by 
the client 2610. At step 28S0, the displays of client 2610 and neighbors 2660 are updated to 
show the new positions in the plex of each user. 

Maximally, the data transmitted can include all registration data regarding all neighbors 
currently within the plex. Minimally, that data can include just the overall nimiber of neighbors 

30 at just the central thought. Alternatively, a mixture of data relevant to neighbors can be sent, 
such as the overall number of neighbors at each thought, plus specific data related to certain 
neighbors ('buddies*) who have either been pre-specified by the client 2610 or whose 
registration data contains certain elements. For example, certain neighbors may be designated as 
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system operators or customer service representatives who arc always available for help to all 
neighbors and whose identity and data will always be available to all neighbors within the plex. 
Representing the Shared Plex . There are numerous methods and combinations of methods 
possible for representing the identity and/or quantity of neighbors at the client's active thought 
5 or at other thoughts within the current plex. Figure 29 illustrates hypothetical screen displays 
resulting from those methods. For example, as in screen shot 2910, a number or icon of variable 
size can be displayed in proximity to the central thought and/or other thoughts within the plex 
representing the quantity of neighbors at those thoughts. As shown in screen shot 2920. if there 
arc only a few neighbors, each neighbor caii be represented by its user name, a dot, or a 

1 0 representative icon or avatar (graphical character). A mixture of the neighbor quantity 

representations or neighbor identity representations is also possible so that there might be a 
quantity indication accompanied by specific identification representations of only buddies. In 
embodiments where the network server 2620 sends a message to all neighbors vAien any 
neighbor changes its current active thought, the plex display of the client 2610 and neighbors 

IS 2660 can be updated to show the movement of neighbors amongst thoughts within the plex as 
screen shot 2930 demonstrates. 

Communications Amongst Neighbors . The present invention can also conveniently 
facilitate communications amongst neighbors. In embodiments where the user table 2650 
contains information relevant to the communications methods available to neighbors, that data 

20 can be made available to the client 2610 and the neighbors 2660. In those embodiments, when a 
user at client 261 0 activates an icon representing a neighbor 2660 within the plex. the client 
2610 requests from network server 2620 the data from user table 2650 identifying the methods 
of communication available to that neighbor 2660. The user at client 2610 can be presented with 
a dialogue box listing the communications methods or protocols conunonly possessed by both 

25 client 26 1 0 and that neighbor 2660. If any of those communications methods are methods 
utilizing a shared communications network such as the intemet, the user at client 261 0 can 
activate the appropriate communications software by selecting the appropriate choice from the 
dialog box. Alternatively, the user at client 2610 can utilize a telephone, mail or other traditional 
means specified within neighbors' communications data. While the specific network 

30 communications software such as intemet telephony, intemet chat, intemet video conferencing 
and electronic mail arc not within the ambit of the current invention, a number of such means arc 
widely available in the art, as are means for creating machine interfaces between the network 
communications architecture of the current invention and those known conununications 
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mediods. 

Tnnrtant P^Mishing of Matricies 
Certain efficiencies can conveniently be achieved under the cunent invention by 
enabling a user of the client software to publish a matrix to a shared network of users. For 
5 purposes of illustration, an embodiment connected with the matrix, thought, and .bra file 

structure and client-server architecture of the current invention is disclosed in this section. Note, 
however, that this aspect of the current invention can be implemented in conjunction with any 
set of references to data shared across a network, such as the "bookmaA" files known in the art 
of internet world wide web design, that are user-configured references to shared network 
10 documents. 

Figure 27 illustrates the minimum requirements of such a shared data structure and 
computer network. Publishing client 2710 is a digital computer running cUent software under the 
present invention, enabling the user to create new matrices, and transmitting those matrices and 
other data to a quick publishing server 2720. The quick publishing server can be the just-in-time 

1 5 server specified above (See, Just-in-Time Model for Sending Flexes, or any other digital storage, 
retrieval and transmission apparatus, such as a computer network server of the type known in the 
art, minimally capable of distributing digital infonnation from a single point to many points or 
cUents in a network. In the prefened embodiment, quick publish server 2720 is a digital 
computer running programs enabling it to (i) receive .bm files bom the publishing client, 

20 maintaining a database 2730 of such published .bra files and other data transmitted by that 

publishing client, as well as statistics related to at least the quantity of usage of those shared .bm 
files by reading clients 2750, and optionally other usage data: (ii) create html or another 
interactive document 2740 that minimally may include a .brs file pointing to the published .bra 
file, and which may include a fimction permitting new reading clients 2750 to download a the 

25 client computer program for reading and/or creating .bm fUes under the current invention; (iii) 
transmit thoughts or .bm files from the database 2730 to the reading cUcnts 2750, for example, 
using the methods described above (See, Just-in-Time Server Model for Sending Flexes;) and 
(iv) optionally monitoring access to the database 2730 by reading cUents 2750. 

The process starts with a user or a computer at publishing client 2710 creating a matrix 

30 .bm file, preferably composed of thoughts whose documents arc commonly available to other 
users by means of a shared digital networi: such as the Internet or other computer network. 
Figure 30 illustrates the process of publishing a shared matrix. 

Software under the present invention permits the user or computer at publishing client 
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2710 to input a command 3010 (preferably by graphical user interface means such as a button or 
menu item) to name and upload that entire matrix to a quick publish server 2730, such as the 
just-in-time server described above (See, Just-in-Timc Server Model for Sending Plexes). Once 
the command is selected, if publishing client 2710 has not previously received the user's e-mail 
5 address (Query 3020) or network uscmame, then at step 3030 the publishing client 2710 

software requests that the user input that information, and optionally may request other relevant 
infomation such as the user's name, a description of the content, and other data that may be 
useful for reading clients 2750 who ultimately will access that matrix from the quick publish 
server 2720. Completing this information input, the user (for example by interactively selecting 

10 an "ok" button) activates an interconnection between publishing client 2710 and the quick 
publish server 2720, which preferably occupies an Internet protocol or other network address 
previously configiured within the software of publishing client 2710. In step 3040. at the quick 
publish server's 2720 direction, publishing client 2710 then transmits the .bm file embodying 
the matrix and the relevant information to a storage device 2730 to which the quick publish 

1 5 server 2720 preferably has constant uninterrupted access. 

In the preferred embodiment, the quick publish server 2720 now transmits a message to 
the user at publishing client 27 1 0 that the data has been sent and to expect a message via email 
or other convenient communications means shortly. The quick publish server 2720 stores the 
.bm file and associated information to the data storage 2730, renaming the .bm file if that data 

20 storage 2730 abeady contains another .bm of that name. (See, steps 3050, 3060, and 3065.) 
Then, at step 3070, the quick publish server 2720 creates a .brs file is created that contains 
network address of the quick publish server 2720, and the location of the .bm file within the data 
storage 2730. The locations of both the .brs and .bm files are added to an index table 2735 
maintained within the data storage 2730. Software at reading clients 2750 enables users to 

25 instruct the quick publish server 2720 that they wish to access the published brri file now stored 
at the digital storage 2730. The method described above, or other methods, can be used to enable 
such access (Sec, Just-in-Time-Server Method for Sending Plexes.) 

In the preferred embodiment, at steps 3080 and 3090, the quick publish server 2720 then 
commxmicates a message to the publishing client 2710, by electronic mail or other known 

30 means, containing a uniform resource locator (URL) or other known network protocol, that 

designates a script The unique name of the published .bm file is incorporated into that script as 
a parameter. Minimally, the URL and the script it designates perform two functions. 

First, upon activation by any of the reading clients 2750, it instructs the qtiick publish 
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server 2720 to generate an html page 2740 or other interactive document optionally containing 

(i) a brief description of the client software under the present invention, and inviting new users 
to download it from the network; (ii) an interactive button or other means permitting users to 
instruct a server to upload the client software to them; (iii) a description of the published Jim 

5 file; and (iv) a link to the .brs fde, the activation of which gives the reading clients 2750 access 
to the .bm file. Second, it updates the index table 2735 to reflect that the designated .bm file was 
accessed. 

In the preferred embodiment, activating a .brs file the html page 2740 may update the 

Index table 2735 to indicate that a certain .bm file was accessed. Optionally, in embodiments 
10 where first-time users of the reading clients 2750 are required to register with the quick publish 

server 2720 by providing certain user inforaiation. the index table can also be updated to reflect 

the nature of user that has just accessed the certain .bm file. 

In a preferred embodiment, to conserve network resources, the quick publish server 

2720 will periodically query the index table 2735 to see if any .bra files are not being regularly 
15 accessed. If not, then the quick publish server 2720 can either delete those bm files ftom data 

storage 2730, or send a message to publishing client 2710 that the bm file is in danger of being 

deleted. 

In addition to the benefits of enabling unskilled users to publish complex content, 
utilizing the customer information database maintained at data storage 2730 enable public users 
20 to search for and identify potential friends, business partoers, or even advertising sites. For 

example, using database search techniques known in the art, users could query the quick publish 
server 2720 to query the database maintained in data storage 2730 for .bra files along a number 
of parameters such as CO containing thoughts named certain key words; (ii) above a certain size; 

(ii) created on, before or after a certain date; (iii) accessed with a certain level of frequency; (iv) 
25 created by male or female user with certain personal characteristics; or even (v) accessed by 

users with certain characteristics. Advertisers could arrange with the proprietor of such a quick 
publish server to display certain advertisements within the html pages generated in conjunction 
with certain .bm access scripts described above, or even within the .bra files themselves as 
tiioughts are accessed, A more complex query might involve instructing the quick publish server 
30 2720, using known database indexing and search techniques, to compare a given .bm file with 
the .bra files stored at digital storage 2730, and output the best matches. 

Speech Recognition 

The present invention also enables substantial advantages v*en adapted as a speech- 
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commanded navigation system. For the puiposes of illustration, an cmb diment connected with 
the matrix, thought and plex structure of the current invention is disclosed in this section. Note, 
however, that this aspect of the current invention can be implemented in conjunction with any 
computer system that provides for file management, browsing, of navigating by identilying files 
5 or pieces of information WinWords in a human language. 

It is well known in the art that one limitation faced by all speech recognition methods is 
the problem of distinguishing amongst the tens of thousands of words in any human language. In 
a speech system adapted for navigating amongst thoughts, the user can activate any thought by 
saying its name, because thoughts are words that can be indexed by their names as well as 
10 numbers. 

Since a matrix will not normally have more than a few thousand thoughts, that speech 
system needs only distinguish amongst that limited set of words. Additionally, that speech 
system can further drastically limit the number of words it needs to compare to the voice 
cpmmand by only checking thoughts in short term memory, or by only checking thoughts that 

15 arc currenUy being displayed On the plex, past thought list, or in pins). Training of such a system 
can also be accomplished by teaching it how each thought sounds when it b created. For 
example, a user could speak the name of a new thought simultaneously with entering it oh a 
keyboard. This way, the system can be very accurate without imposing upon the human user a 
tedious and slow training session. 

20 Parallel Web 

Prior art information networks systems lack a method of relating data relevant to shared 
documents to particular users, without changing those shared documents. Another aspect of the 
present invention, a "parallel web" system, enables network users to create content that is 
associated with particular web pages or network documents, but is visible only to a select group 

25 of network users. 

A parallel web offers users of the present invention to share and view matrices and notes 
related to web pages and other shared content For purposes of illustration, this section discloses 
embodimMts related to the thought, plex, matrix and client server architecture of the present 
invention. Note, however, that a parallel web can be implemented in conjunction with any data 

30 that users wish to associate with shared content and distribute to select other users. Examples of 
that additional data include alternative navigation systems, private comments about common 
shared data, usage statistics, enhanced content for users widi high bandwidth connections, links 
to related data, or even contests amongst multiple users of shared data. 
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Operating ? f arallel Web . Figure 31 Ulustrates the minimum requirements of a parallel 
web's shared data structure and computer networic. Qient computer 31 10 is a digital computer 
running two types of client software functions. It runs a primary web browser 3120 or document 
retrieval system minimally cqjablc of displaying documents loaded from a primary server 
5 computer 3140. It also runs a parallel browser 3130 minimally capable of displaying associated 
items of parallel content 3 1 90 downloaded from a parallel server computer 3 170, using a method 
of monitoring the actions of primary browser 3120 such as that iUustrated in Figure 32. In the 
preferred embodiment, that paallel browser 31-0 operates in the background, invisible to the 
user, until it automatically activates itself to display items of parallel content 3 190 to the user. 

1 0 Primary server computer 3 140 is a digital computer such as a conventional network or 

internet server running a primary server 3 150 software fimction such as a web or other document 
server, and storing primary content 3160 such as web pages, network documents, motion 
pictures or other content Primary server fimction 3150 minimally is capable of uploading items 
from that primary content 3160 upon request by primary browser 3120. 

1 5 Parallel server computer 3 1 70 is a digital computer such as just-in-time server discussed 

above running a parallel server 3180 software fimction, storing parallel content 3190. and 
indexing that content in a table 3195 correlating items of parallel content 3190 to the addresses 
or URLs to associated items of primary content 3160. Parallel server fimction 3180 minimally is 
capable of uploading items from that parallel content 3190 upon request by parallel browser 

20 3130, using a method of responding to requests such as that illustrated in Figure 33, 

Note that the parallel server computer 3170 and the primary server computer 3140 can 
be the same digital computer operated by a single user or administrator. Alternatively, the 
parallel server computer 3 1 70 can be operated by a separate user wishing to offer content 
associated with yet distinct from items of primary content 3 1 60. 

25 In one embodiment, parallel browser 3130 loads and displays items of parallel content 

3190 in synch with primary browser's 3120 requests for items of primary content 3160 
according to tiie method Ulustrated in Figure 32. At step 3210, using known methods of 
monitoring the addresses of documents accessed form a network using popular browsers such as 
Netscape's Navigator and Microsoft's Internet Explorer, the parallel browser 3130 monitors 

30 whether the primary browser 3 120 has requested a document of a different address or URL from 
a primary serf a 3150. If primary browser 3120 has not changed URLs, the parallel browser 
3130 waits at step 3210 and reinquires. If the primary browser has changed URLs, tiien the 
parallel brovk^er 3130 stops displaying die current item of parallel content, if any. In a preferred 
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embodiment, the parallel browser 3130 and the parallel server 3180 can be set to ignore a 
portion of the URL. so that hems of parallel content 3 1 60 can be made to appear simultaneously 
not just with an item stored at a specific URL (such as 

'http://www.acme.coraJroadrunner/trapsIbannana~,„peels"), but also within a certain directory 
5 or within a certain domain (such as "http:/Avww.acme.com"). Applying the plex and matrix 
means of the current invention, not just one document, but a group of documents can be made to 
correspond to a single thought within a plex in this manner, and the user's plex display would 

not be updated by the just-in-time server method described above. 

At step 3230, the parallel browser 3130 then sends a query to parallel server 3180, 
1 0 inquiring, according to a method such as the one illustrated in Figure 33 , whether there is any 
item of parallel content 3 190 associated with that URL. If parallel server 3 1 80 uploads an item 
of parallel content in response, then at step 3250, the parallel browser commands display means 
in client computer 3 1 10 to display that item. In a prcfened embodiment, a parallel browser 3 130 
can be configured with multiple channels to seek various sources of parallel content either fiom 
1 5 the same parallel server 3 1 80 or from a different parallel computer 3 1 70 entirely. The parallel 
content available through those different channels can vary by the sort of content (video, plexes. 
comments, contest data), or by various sources of similar content. For example, it is possible that 
more than one shared matrix under the current invention possesses a thought corresponding to 
that URL, and the parallel browser 3 1 30 could be configured to send queries to more than one 

20 just-in-time matrix server. 

So if no items of parallel content 3190 arc received from the parallel server 3180 at step 
3240. or following the display of the newly received parallel content at 3250, then at step 3260 
parallel browser 3 130 inquires whether the user has stipulated additional channels. If so, then the 
parallel browser 3130 again queries the appropriate parallel server 3180 at step 3230. If not, then 

25 returning to step 3210. the parallel browser again checks the primary browser 3 120 has changed 
URLs. 

Corresponding to the parallel browser method illustrated above is a method that can be 
used by parallel server 3180 to upload appropriate items of parallel content Figure 33 illustrates 
such a method. At step 3310, paraUel server 3180 monitors whether it has received a request 
30 fiom any parallel browser such as 3130. Such a request contains a URL bemg activated by 
primary browser 3 120, and optionally the identity of a specific channel within the items of 
parallel content 3190. At step 3320, parallel server 3180 checks parallel content table 3195 to 
see if there are any items of parallel content 3190 corresponding to that URL and channel. If no 
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parallel content items are found, then paraUel server 3 1 80 sends a negative response to parallel 
browser 3130 and returns to step 33 10 to continue monitoring for incoming requests from 
parallel browsers. If the table 3195 indicates that any item of parallel content 3190 does 
correspond to the requested URL and channel, then that item is uploaded to parallel browser 
5 3 1 20. Note that in an alternative embodiment, the parallel server function 3 1 80, the parallel 
content table 3195, and the parallel content 3190 can all reside on different digital computers 

linked in a network. 

/Adding Parallel Content One benefit of the parallel web is that users can make 
additions to the parallel content 3190 at any time, since parallel browsers such as 3130 requery 

10 the parallel server 3180 every time the primary browser 3120 changes URLs. ParaUel content 

can be offered by any party in relation to his own primary content 3 1 60 or the primary content of 
another. Those additions, of course, do not change any aspect of the corresponding primary 
content available to networic users. 

The process for adding to parallel content 3190 is simple. A user sends items of parallel 

15 content, along with the corresponding primary content URL, and channel identifier, if any, to a 
parallel server 3 1 80. The user also specifies whether existing parallel content is to be replaced or 
augmented. Different users can be assigned different access privileges for this purpose according 
to means known in the art of network management The paraUel server 3180 then cither denies 
the addition because the user lacks access privileges, or updates parallel content table 3195, and 

20 makes the appUcable modifications to parallel content 3190, optionaUy in a manner dictated by 
that user's access privileges. 

Depending on the embodiment or application of this parallel web system, the access 
privileges or rules for when a parallel server 3 1 80 should permit or deny modifications to 
paraUel content 3 1 90 vary. 

25 For a commenting or annotation embodiment in which the paraUel content is 

commentary yxpon the primary content, users may be spUt into groups and given access 
privUeges for different URLs and or channels. Some users may never be allowed to change 
paraUel content, others may only be allowed additions only, whUe stUl others may be allowed to 
make all dianges. 

30 In some embodiments, the rules may be determined dynamicaUy. The simplest case is 

one where a governing body (a company or person) chooses which requests are granted and 
which are denied based upon subjective judgments. A tournament amongst users represents a 
sUghUy more complex case. Users could compete widi one another in games of skiU or luck to 
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determine who gets the privilege of planting his flag or oistom content in relation to a certain 
URL. A World Wide Web embodiment of a parallel web contest would offer the best 
competitors the ability to distribute their parallel content in relation to a highly popular website 
primary content Less skillful competitors would be forced to settle for planting their parallel 
5 content flag on less frequented primary content websites. 

In a navigational embodiment, such as the instant publishing of shared matrices imder 
the current invention, users could compete for the right to make parallel content matrices 
available in relation to popular primary content websites. Alternatively, access privileges to 
change parallel content matrices could be allocated by other criteria such as how recent the last 
1 0 update was made, matrix size, matrix popularity, or fees. 

Spider Site 

The present invention permits a matrix to be automatically generated from a hypertext 
document. This document becomes the central thought, and the linked items within the 
document become children thoughts. Those linked children may subsequently be explored in a 

1 5 similar manner. In cases where hypertext uses somewhat predictable link names, the present 
invention may link thoughts in a more context-sensitive manner. For instance, files located on a 
remote compxrter or Internet URL may be displayed as jump thoughts, and files which are 
disposed in a hierarchical directory location above the current directory may be displayed as 
parent thoughts. This method for automated generation of matrices may be restricted so that it 

20 does not create overly cumbersome plexes. For example, it may be designed so that it does not 
create thoughts relating to files located on remote machines. 

In particular, the present invention has the capacity to automatically generate a matrix 
corresponding to a map of a web site. A server can be employed to create and store such matrix- 
maps, and to send cached versions of the matrix-maps upon request The sites to be mapped by 

25 this server may be identified through a list provided to the server, or the server could use web 
crawler techniques presently known to those of ordinary skill in the art to identify sites to be 
m^sped. 

Figiire 34 provides a flow diagram showing the basic steps of an algorithm for 
generating a matrix corresponding to a map of a web site or other set of self-referencing, linked 
30 files. A new thought is created within a matrix utilizing a web page's Internet Uniform Resource 
Locator ("URL'O as that new thought's location and the contents of the web page's Hypertext 
Markup Language ("HTML**) "<TnLE>" tag as its thought name. A source list is then created 
and the thought location assigned to the web page is added to the source list Another list, an 
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empty destination list, is created. 

Referring to Figure 34, in step 341 0, a user specifies how many levels of hyperlinked 
pages associated with the web page should be searched, with each level consisting of those pages 
directly accessible by actuating a single hyperlink contained in the immediately higher level. 
5 The search will be repeated on each level of web pages hyperlinked that the user specified in 
step 3410. 

Referring to Figure 35, in an exemplary operation, a dialog box appears and asks the user 
to specify the depth for which the hyperlinked pages associated with the web page should be 
searched. In step 34 1 0, the user may also specify, by enabling "Add Redundant", that hypcriinks 

1 0 which correspond to thought locations of existing thoughts should be linked to the thought of the 
web page bearing its hyperlink (steps 3421a and 3421b). Additionally, by enabling "Add Non- 
Local", a user can specify that non-local hyperlinks found within the HTML be considered for 
inclusion as thoughts within the matrix (steps 341 8a and 341 8b). Finally, by enabling "Spider 
Non-Local", a user can specify that a matrix corresponding to a map of a non-local hyperlinked 

15 file be created. 

For each thought location in the source list, steps 3412 through 3426 arc executed. One 
by one. the thoughts corresponding to each thought location in the source list are activated and 
th'j corresponding HTML downloaded (step 3412). The HTML is then searched for hyperlinks 
(step 3414). 

20 For each hyperiink found within the HTML (step 3416), steps 3418a through 3426 are 

executed. In step 3418a, the hyperlinks found in step 3414 are determined to be local or non- 
local hyperlinks. The algorithm proceeds to step 3419 for all local hyperlinks found within the 
HTML. If the user preference is that non-local thoughts be considered for addition to the matrix 
as well, the algorithm proceeds to step 3419 for non-local hyperiinks (step 34 1 8b). Otherwise. 

25 the algorithm returns to step 341 6. Other criteria could be used to determine the suitability of 
hypcriinks. For example, a user could confirm or skip individual hypcriinks at the user's 
discretioiL 

In step 3419, the matrix is searched to determine whether a hyperlink corresponds to any 
thought location of any existing thoughts (step 3420). 
30 Step 3422 is executed for non-existing thoughts. For a non-existing thought, in step 

3422, new thoughts are created within the matrix, utilizing the URLs wifliin each respective 
hyperiink as thought locations. 

The displayed text in the case of a hypertext link or the "Alt Text" in the case of a 
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graphical link is used as the thought name. The newly created thought is then linked to the 
thought of the web page bearing its hyperlink (step 3424). Usmg known techniques, the type of 
link can be determined based on the following rules: children are the default, jumps are for 
URLs in another domain and parents are for URLs that are located higher in the web page's 
5 directory structure. Other rules, such as deciding based on existing or number of links, can also 
be applied. 

For hyperlinks which corresponds to any thought location of any existing thoughts 
(step 3420), if the user preference is that such existing thoughts be added to the matrix (step 
342 1 a), that active thought is linkwl to the thought of the web page bearing its hyperlink 
1 0 (step 3421b). Otherwise, the algorithm returns to step 3416. 

At step 3426, ail thoughts treated in step 3424 are added to the destination list. 
Steps 3412 through 3426 are repeated for each thought location in the source Hst and 
then for each level of hyperlinks specified at step 3410 until there are no more thoughts in the 
source list to be considered (step 3427). At that pomt, the source list is cleared and the contents 
15 of the destination list are moved to the source list (step 3428). 

In step 3430, if there are no more thoughts in the source list, the process ends. If there 
arc more thoughts in the source list, then it is determined whether the number of levels of 
hyperlinks associated with the web page specified to be searched by the user in step 34 10 has 
been reached (step 3432). If the number of levels has not been reached, the process retums to 
20 step 3412. The process ends if the number of search levels has been reached (step 3432). 

Virtual Thoughts 

As is illustrated in FIG. 36, the present invention provides for the automated generation 
of thought matrices Scorn preexisting independent groups of information, thereby facilitating 
navigation through such groups of information. The independent groups of information may 
25 include, but arc not limited to, directories such as ^mdows® directories, networks such as the 
internet, databases and linked items such as a web site compatible with the present invention. 

Once generated, these new matrices are visualizable and navigable in accordance with 
the present invention. For example, the present invention automatically generates matrices that 
pemiit navigation through files or folders resident on a hard disk using the actual hard disk as a 
30 reference for the display. To assure that the representation of those files or folders remains useful 
notwithstanding changes to their content, it is preferable that the disclosed system directly 
references the original file or folder rather than a copy of the information that was contained in 
that file or folder at one moment in time. In this maimer one can make changes in those files or 
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folders indq)endcnt of the presently disclosed system, and these changes will be reflected in the 

visualization furnished by the present invention. 

For some applications the advent of so-called **virtual thoughts" minimizes imnecessary 
expenditure of system resources and otherwise facilitates the generation, storage, visualization, 
5 or navigation of these automatically-generated matrices. "Virtual thoughts" arc temporary 

thoughts that are created for limited purposes. Virtual thoughts are advantageously employed in 
the processing of information from independent groups of information such as Windows® 
directories, networks such as the internet, or other databases compatible with the present 
irivention. _ 

10 The use of virtual thoughts permits the limited generation of thought matrices from 

independent data structures. This generation process is "limited" in the sense that it does not 
require creation of thoughts corresponding to each and every piece of information in the 
independent structure. The process of matrix generation using virtual thoughts, instead, 
preferably is restricted to creating thoughts conesponding to a limited category of the available 

IS pieces of information. 

In many respects using virtual thoughts to navigate an extremely large hierarchy of 
information is analogous to a traveler creating a roadmap, while travelling, that predicts the 
roads a few miles ahead but contains no information about areas outside the immediate vicinity. 
In one embodunent, virtual thoughts are created only as they become necessary to navigate a 

20 plex, and once created they are remembered only so long as they are required to return to the 
source thought that originated their creation. Thus at each step through a plex new virtual 
thoughts may be created or deleted as necessary to navigate, but there is no requirement that 
thoughts be created for information that has no inunediate relevance to navigation. The process 
of restricting virtual thought creation to thoughts referencing only a limited subset of 

25 information resident in a data structure is referred to as "limited virtual thought creation." The 
subset of limited virtual thought creation processes in >\1iich thought creation is limited to 
creation of thoughts referencing documents in the navigational vicinity of the presently-selected 
thought (i.e., a thought closely related to the presently-selected thought where relations as 
determined by the associative relations of the present invention) is referred to as "localized 

30 virtual thought creation.** Accordingly one may utilize the present invention to efficiently 
navigate immense or even endless arrays of interrelated pieces of information, such as a large 
Windows® directory or even the entire intcmet, without needless and costly processing or 
display of irrelevant information. In some applications the advances herein disclosed allow the 
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navigation of vast seas of infonnation in real time, or substantially real time. 
Creation and Use of Virtual Thoughts 

The input of any command that necessitates the creation of a new virtual thought 
initiates the process of virtual thought creation, one embodiment of which is illustrated in Figure 
5 37. For example, when a thought is activated that is linked to a folder (the "folder thoughO in a 
Windows®-based hierarchy (step 3900), the present invention automatically generates a limited 
thought matrix derived from thai hierarchy. During that automated process the contents of the 
directory are queried (step 3902), and the results of the query arc stored as a thought for each file 
and folder in the directory (step 3904). These thoughts are flagged as being 'Virtual" thoughts 

10 (step 3906) and arc linked to their respective files and folders (step 3908). These thoughts are 
then linked to the folder thought as children (step 3910). 

The portion of the invention that saves thoughts to permanent storage ignores virtual 
thoughts, so that virtual thoughts are never permanently stored. Similarly, the links to virtual 
thoughts are not permanently stored. In many other respects, however, the preferred embodiment 

15 of the invention treats virtual thoughts the same as non- virtual (hereinafter "normal'O thoughts. 
For example, the interface of the present invention allows virtual thoughts to be activated, 
highlighted, and moved. Virtual thoughts furthermore are displayed in a plex in a manner similar 
to that used for the display of normal thoughts. To graphically differentiate normal and virtual 
thoughts in a plex, virtual thoughts are colored differently than normal thoughts. The color 

20 schemes assigned to virtual thoughts may further be employed as indicia as the source of the 
virtual thoughts. 

As one navigates a plex containing virtual thoughts, the creation of additional virtual 
thoughts often becomes necessary. For example, activating a virtual thought that is linked to a 
folder may necessitate creation of additional virtual thoughts to represent certain files or folders 
25 associated with the nev^y activated virtual thought Thus through recursive creation of virtual 
thoughts, a folder system can be explored to its deepest levels even if the only "real*" link is 
through a thought that is linked to the top level of the hierarchy. 

Deletion of Virtual Thoughts 
In one embodiment of the present invention, referred to as "non-localized virtual thought 
30 deletion," virtual thoughts are automatically eliminated from the memory of the system used to 
implement the disclosed methods when those thoughts are no longer required to return to the 
source thought that originated their creation and arc no longer needed for display. One example 
of such a process is illustrated in Figure 38. As one browses throiigh the hierarchy by selecting 
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new central thoughts (step 4000) the invention automatically identifies a list of the thoughts that 
are required to return to a nonnal source thought and/or required for display (step 4002). 
Throughout the browsing process, as new thoughts arc activated or as old thoughts are revisited, 
certain virtual thoughts become immaterial and are deleted. The invention automatically 
5 identifies thoughts that are both not required to return to a normal source thought (step 4004) 
and not required to be displayed (step 4006), and deletes them (step 4008). Preferably this 
deletion process is transparent to the user. Of course with other embodiments virtual thoughts 
may be retained in memory for any desired length of time or until any preselected set of 
conditions is satisfied: For example, virtual thoughts not presently required for display or return 

10 to a nonnal thought could be deleted 

when the need arose for space in a segment of memory dedicated to virtual thought storage 
occasioned by the creation of a new virtual thought The process of deleting a portion of the 
virtual thoughts upon the satisfaction of a preselected conditions is referred to as "limited virtual 
thought deletion.'' Finally, any virtual thoughts deleted fi-om memory can be be recreated, if they 

15 are ever required for re-display, in accordance with the above-disclosed virtual thought creation 
process. 

Conversion of Virtual Thoughts To N onnal Thoughts 

Occasionally a user of the present invention desires to change a file or folder that is being 
accessed as virtual thought For example, a user may wish to store additional information about, 
20 or otherwise amend, such a file or folder. Such a situation may arise when a user creates a new 
link to a virtual thought or v^en the user adds notes to a virtual thought. Those changes, 
however, cannot be stored as part of the file system so long as the virtual thought remains 
virtual. Accordingly, the thought can be converted to a normal thought for purposes of recording 
changes to its content 

25 When a first virtual thought is converted to a normal thought, in some instances it is 

advantageous to convert other virtual thoughts so that the first converted thought appears in the 
same context as it appeared prior to its conversion. If such additional conversion is desired, the 
thoughts that define the path to the source thought for the first converted thought can also be 
converted to normal thoughts. This additional conversion is preferably is accomplished by 

30 automatically identifying the thoughts connecting the fust converted thought to a source thought 
and then converting any virtual thoughts among the identified thoughts into normal thoughts. 
Redundancy Avoidance 

Checks to avoid redundancies (refened to as "redundancy avoidance checks**) when 25 
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creating new virtual thoughts are advantageously implemented in one embodiment of the 
invention. These redimdancy avoidance checks are beneficial because normal thoughts and 
virtual thoxights can potentially represent the same file or folder, and because virtual thoughts 
may still be in existence when new virtual thoughts that represent the same piece of data arc 
5 being created. These checks arc typically perfonned at the time of creation of a virtual thought, 
and require comparison of existing normal thoughts and virtual thoughts to the virtual thoxights 
about to be created If redundancies exist, the new virtual thought is not created. 
Further Applications 

- While the use ofvirtual thoughts has primarily been described with refercnw^ 

10 navigation a foldcr-and-filc system, one of ordinary skill would recognize the wide range of 
other groups of information that could be navigated or visualized using virtual thoughts. Merely 
by way of example, a thought may be linked to a database query, and the results of that query 
could be displayed as virtual thoughts. Furthermore, many generations of virtual thoughts can be 
created by using the first-created set of virtual thoughts to create a second set, and so on. In the 

15 case of a foldcr-and-filc system, for example, the invention can create the generation of virtual 
thoughts that are related to each of the thoughts in the first set of virtual thoughts. Similarly, in 
the embodiment wherein a thought is linked to a database query, virtual thoughts could be used 
as additional filters to the query so as to obtain a second generation of virtual thoughts. 

Detailed illustrations of an improved scheme of organizing information by an associative 

20 thought process in accordance with the present invention have been provided above for the 
edification of those of ordinary skill in the art, and not as a limitation on the scope of the 
invention. Numerous variations and modifications within the spirit of the present invention will 
of course occur to those of ordinary skill in the art in view of the embodiments that have been 
disclosed. For example, while in the described embodiment, the present invention is 

25 implemented for a GUI for desktop computers or local area or wide area computer networks 
(e.g., the Internet), the present invention may also be effectively implemented for any 
information ^pliance which can take advantage of the novel associative thought scheme of the 
present invcntiort The scope of the inventions should, therefore, be determined not with 
reference to the above description, but should instead be determined with reference to the 

30 appended claims, along with the fiill scope of equivalents to which such claims are entitled. 
What is claimed is: 
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CLAIMS 

1 . A method for navigating a group of information in a computer system, comprising the 
steps of: 

identifying said group of information associated with a selected data item; 
5 converting certain pieces of said group information into generated data items; 

associating imilateral and multilateral display relationships with said generated data 
items, each unilateral display relationship representing a direct relationship between two of said 
generated data items, and said multilateral relationships also representing an indirect relationship 
-with other generated data items; - - 
10 associating unilateral and multilateral display relationships with said generated data 

items and said selected data item, each unilateral display relationship representing a direct 
relationship between said selected data item and one of said generated data items, and said 
multilateral relationships also representing an indirect relationship between said selected data 
item and said generated data items; and 
15 forming a display associated with said selected data item, including said generated data 

items, wherein said display distinguishes between said selected data item and said generated data 
items. 

2. The method claimed in claim 1 , wherein said group of information comprises a 
20 directory. 

3. The method claimed in claim 1 , wherein said group of information comprises a 
hierarchical group of informatioiL 

25 4. The method claimed in claim 1 , wherein said step of converting certain pieces of said 
group information into generated data items further comprises the step of: 

converting certain pieces of said hierarchical group of information into a nonhierarchical 
group of information. 

30 5. The method claimed in claim 1 , wherein said display graphically distinguishes between 
said selected data item and said generated data items. 



6. 



The method claimed in claim 5, wherein said selected data item is colored differently 
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7. The method claimed in claim 1 , wherein said step of converting certain of said pieces of 
information into generated data items further comprises the step of: 

converting those pieces of information disposed in a navigational vicinity of said 
selected thought into generated data items. 

8. The method claimed in claim 7, wherein said navigational vicinity of said selected 
thought comprises an area within said display. 

9. The method claimed in claim 1, further comprising the step of: 

eliminating said generated data items in accordance with a predetermined condition. 

10. The method clauned in claim 9, wherein said step of eliminating said generated data 
items in accordance with a predetermined condition further comprises the step of: 

eliminating said generated data items from a memory of said computer system. 

1 1. The method claimed in claim 9, wherein said step of eliminating said generated data 
items in accordance with a predetermined condition further comprises the step of 

eliminating said generated data items which are no longer disposed in said navigational 
vicinity of said selected thought on said display. 

12. The method claimed in claim 9. wherein said step of eliminating said generated data 
items in accordance with a predetermined condition further comprises the step of: 

eliminating said generated data items which are no longer required to return to said 
selected data item. 

13. The method claimed in claim 1 , wherein said selected data items are permanent data 
items. 

1 4. The method claimed in claim 1 3, further comprising the step of: 
converting certain of said generated data hems into permanent data items. 



S8 



wo 00/57257 PCTAJSOO/06640 
15. The method claimed in claim 1, wherein said group of information comprises a database. 



16. The method claimed in claim 1, wherein said gro\ip of information comprises a set of 
linked items. 

5 

17. The method claimed in claim 16, wherein said linked items comprise a web site. 

18. An apparatus for navigating a group of information in a computer system, 
comprising: 

] 0 means for identifying said group of information associated with a selected data item; 

means for converting certain pieces of said group information into generated data items; 
means for associating imilatcral and multilateral display relationships with said 
generated data items, each unilateral display relationship representing a direct relationship 
between two of said generated data items, and said multilateral relationships also representing an 
1 5 indirect relationship with other generated data items; 

means for associating unilateral and multilateral display relationships with said 
generated data items and said selected data item, each unilateral display relationship representing 
a direct relationship between said selected data item and one of said generated data itans^ and 
said muhilateral relationships also representing an indirect relationship between said selected 
20 data item and said generated data items; and 

means for forming a display associated with said selected data item, including said 
generated data items, wherein said display distinguishes between said selected data item and said 
generated data items. 

25 1 9. The apparatus claimed in claim 1 8, wherein said group of information comprises a 
directory. 

20. The apparatus claimed in claim 1 8, wherein said group of information comprises a 
hierarchical group of informatioa 

30 

2 1 . The apparatus claimed in claim 1 8, \^dierein said means for converting certain pieces of 
said group information into generated data items further comprises: 

means for converting certain pieces of said hierarchical group of information into a non- 
59 
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hierarchical group of information. 

22. The apparatus claimed in claim 18, wherein said display graphically distinguishes 
between said selected data item and said generated data items. 
• 5 23 . The apparatus claimed in claim 22, wherein said selected data item is colored differently 
fipom said generated data items. 

24. The apparatus claimed in claim 1 8, wherein said means for converting certain of said 
pieces of information into generated data items further comprises: 

1 0 means for converting those pieces of information disposed in a navigational vicinity of 

said selected thought into generated data items. 

25. The apparatus claimed in claim 24, wherein said navigational vicinity of said selected 
thought comprises an area within said display. 

15 

26. The apparatus claimed in claim 18, further comprising: 

means for eliminating said generated data items in accordance with a predetermined 

condition. 

20 27. The apparatus claimed in claim 26, wherein said means of eliminating said generated 
data items in accordance with a predetenmined condition further comprises: 

means for eliminating said generated data items from a memory of said computer 

system. 

25 28. The apparatus claimed in claim 26, whercm said means for eliminating SMd generated 
data items in accordance with a predetermined condition further comprises: 

means for eliminating said generated data items which are no longer disposed in said 
navigational vicinity of said selected thought on said display. 

30 29. The apparatus claimed in claim 26, wherein said means for eliminating said 
generated data items in accordance with a predetermined condition fiather comprises: 

means for cUminating said generated data items which are no longer required to return to 
said selected data item. 

60 
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30. The apparatus claimed in claim 18, wherein said selected data items are pennanent data 
items. 

3 1 . The apparatus claimed in claim 1 8, further comprising: 

means for converting certain of said generated data items into permanent data items. 

32. The apparatus claimed in claim 18. x^erein said group of information comprises a 
database. 

33. The apparatus claimed in claim 1 8, wherein said group of information comprises a set of 
linked items. 

34. The apparatus claimed in claim 18. wherein said linked items comprise a web site. 
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Cortex Software is dedicoted to providing technology 
products which ore inherently superior by virtue of their 
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boolean CheckForlsololion(inl centrolThoughl, int torgetThought) 

1 

//this function checks if centrolThoughl is reloted to torgetThought 
// vio any of torgelThought's relations (not directly) 

//remove centrolThought os a direct relolion from torgetThought 
RemoveRelalion(lQrgetThought. centrolThought); 

//Creole on empty thought list to keep Irock of the scorch 
intList searchList=Creote&npt)lisl(); 

//start recursive seorches on eoch of torgetThought s direct relations 
int relolion=GetnrslRelotion(torgetThought); 
boolean found; 
do { 

found=Seorch(relation. centrolThought, seorchList); 
if{found) I 

//centrolThought was found, no need to search any further 
break; 

I 

//this loop will end when there ore no more relotions 
I while(relation=GelNextRelation(targetThought); 

//odd centrolThoughl bock onto torgetThought os o relotion 
AddRelation(torgetThoughl, centrolThought); 

return found; 

I 

FIG. 10a 
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Figure 10. cont'd 
booleon Search(source, desl, seochLisl) 

( 

if(Find(source, searchUsl)) | 

//source has olreody been searched 
return FALSE; 

1 

//odd source to the seorchList 
Add(source. seorchList) 

if(source =dest) j 

//this is the destlnolion.we hove found it 
return TRUE; 

I 

//recursive searches on eoch of sources direct relolions 
int relotion=GetRrstRelotion(source); 
booleon found; 
do j 

found=SeQrch(relalion, desl, seorchList); 
if(found) { 

//centrolThought wos found, no need to search ony further 
break; 

1 

//this loop will end when there ore no more relolions 
j while(relolion=GetNexlRelolion(targetThoughl); 

return found; 

FIG. 10b 
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There ore very few applications thot ore useful to olmost everyone. Acluolly, 
there is currently only one: the word processor. 




The Brain will be o universally oppeoling opplicotion. It will be one of the most 
significont new technologies in decodes. The first only thought processor. 
Softwore that does for thoughts whot the word processor does for words. 




The Brain opprooches the computer os o computer, not o glorified typewriter, 
calculator, filing cabinet, or day-book. Not surprisingly, the bosis of most 
produclhnly opplicotions ore concepts from the pre-computer oge. By storting 
with munddne, non-revolutionary task metophors, these opplicotions ore all 




FIG. 13 




SUBSTITUTE SHEET (RULE 26) 





wo 00/57257 



PCTAJSOO/06640 



14/37 



O Cortex'^ 




O Rodin 
o 



O Liquid Noise ^ 
o \ 



960 



O Resources ^ 



O Informolion 



□ Colendor 



Week of June 3, 1996 



Monday 3 



Tuesdcw 4 



Wednesdoy 5 



0 Reseorch 
Liquid Noise 
Contoct Teom 



±3 



1:00 PM Cortex 
St/ff Meeting 



Thursdoy 6 



/idoy 7 



9:00 AM 
Meeting with 
Liquid Noise 
Contoct Team 



Soturdoy 8 



Sundoy 9 



1510 



FIG. 15 



SUBSTITUTE SHEET (RULE 26) 



wo 00/57257 



PCTAJSO0/D6640 



15/37 



.bm f3e 



heoder information 

signature 

version 

thought size 
number of thoughts 
other thought number 



preference informotion 

signoture 

color preferences 

speeds times 

locotions 

other preferences 



thought dota 




thought 1 






number 






children 






parents 






jumps 






name 






location 






keywords 






category 






events 






time active 






time aeoted 






time modified 






tffne accessed 






time forgotten 






access category 






priority 






calendor event info 






is blank 






current version number 








thought 2 








thought 3 








••• 







FIG, 16 



SUBSTITUTE SHEET (RULE 26) 



wo 00/57257 



PCr/USOO/06640 



16/37 



ForgelThoughl (fNum) 



I 



//mark oil the children of the selected thought 
list.aear(); 

MorkChildren (fNum, list); 

//unmork the active thought 

list, RemoveThoughl (octiveThought); 

//unmork thoughts with unmarked porents 

INum = lisLGetFirstNumO; 

while{INunrv !=-0) 

^ if(lNum != fNum) //don t unmork the selected thought 

pNum = GetRrslThoughtPorent (INum); 
while(pNum != 0) 

^ if(list.Contains(pNum) == FALSE) 



if(lsThDughllnLongTermMemory (pNum) == FALS) 

I 

//unmork oil the chSdren of the unmarked porent 
childLislClear(); 

|ylarkChfldren(pNum, childUst); 
list.RemoveUst(chQdList); 

I 

pNum = GetNextThoughlPorenl(INum); 



I 



INum = lislGetNextNumO: 



//now forget all the thoughts left on the list 
Wm - lisLGetFirstNumO: 
while(iNum != 0) 

ForgetThought(INuni); 
INum ' lislGetNexlNumO: 



I 



I 
! 

RememberThought(rNum) 

{ 

//maV oil the chBdren of the selected thought 
list.aear(); 



1 



MorkChildren(rNum. list); 
// remember oil the thoughts on the list 
INum = list.GelFirslNumO: 
while(lNum != 0) 



\ 



Remember Thought{INum); 
INum - listGetNextNumO; 

I 

MarkChildren(num. list) 



\ 



lisl.AddThought(num); 
cNum = GetFirslChild(num); 
while{cNum != 0) 

I 

MarkChildren(cNum, list); 
cNum s GetNextChadfnum); 

I 
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Algorithm for drowing the plex with distonl thoughts 
1. Create o list of thoughts to be drawn ond their on screw locations: 



2. Add the central thought to the list. 

3. Add chadren to the list. 

4. Add porents to the list. 

5. - - Add jumps to the list. 

6. Add sblings to the list, checking first that they are not 

olreody on the list. 



7. Add distonts of children to the list, chedcing first thot they 

ore not olreody on the list. 

8. Add distonts of porents to the list, checking first that they 

ore not already on the list. 

9. Add distonts of jumps to the list, checking first that they 

ore not already on the list 

10. Add distonts of siblings to the list, checking first that 

they ore not olreody on the list. 
11. Drow the lines that connect each thought: 

12. For each item in the list: 

13. Get eoch item in the list: 

14. If the two items ore related, draw lines 

between them from and to the oppropriote 
gotes. 

15. Draw the distonl thoughts: 

16. For eoch item in the list 

17. If it is 0 distant thought, draw it. 

18. Drow the other thoughts: 

19. For each item in the list 

20. If it is not o distent thought, draw it 

FIG. 23 
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line connects the melhod for seorching thoughts ^^^^^ 

lines lo find o route from nSrc to nDest other than a direct relotion 

relums TRUE if found 

boolean SeQrch(inl nSrc inl nDest) 

I //create the lists 

ThoughtUsl posLisl; lis! of thoughts thot possibly conned 
ThoughtList notLisl; list of thought thot do not connect 
//empty the lists 

podJst.lnitidize(); 

notList.lnilializeQ; 

//odd the source to the not list since we cannot go directly to the deslinotion 
notList.Add(nSrc); 

//since we cannot go directly to Ihe deslinotion, 

//odd oil relotes except the deslinotion to the possible list 

Thought src(nSrc); 

for(int n = 0; ; n++) 



\ 



int nRd = src.GelRelQte(n); 
if(!nRel) 

^ //no more relations, done 
breolq 

if(nRel != nOest) 

//odd it to the possibly connect list 
I posList.Add(nRel); 

! 

while(TRUE) 

^ //check the first possibJily 
inl nTest = posUstCetRrslO; 
if(!nTest) 



//nothing on the list, done 
bredq 



f 
I 

Ihought lest(nTesl); 
if(testlsReiated(nDe5t)) 



"ml nRd = lest.GelRelote{n); 
if(!nRel) 

^ //no more relolions, done 
j break; 

if(!notUsLExists(nRel)) 
I 

//not checked yet, odd to possible list 
posList.Add{rel); 

1 ^ 

//remove this one from the possible list 
posLisLRemove(nTest); 

// we've checked everything there is 
no other woy to get from nSrc lo nDest 
return FALSE: 



//this one is rcloted to the deslinotion, weVe done 
return TRUE: 



I 

1 

//does not connect, add it to the does not connect list 
nolUst.Add(nTest); 

//add oil related thoughts except those already checked to possible list 
forjint n = 0; ;++) 

I 
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